Wayang - Jenis dan Penyedia
Jenis boneka digunakan untuk manajemen konfigurasi individu. Wayang memiliki tipe yang berbeda-beda seperti tipe jasa, tipe paket, tipe provider, dll. Dimana setiap tipe memiliki provider. Penyedia menangani konfigurasi pada platform atau alat yang berbeda. Misalnya, tipe paket memiliki penyedia aptitude, yum, rpm, dan DGM. Ada banyak jenis dan Puppet mencakup item manajemen konfigurasi spektrum yang baik yang perlu dikelola.
Wayang menggunakan Ruby sebagai bahasa dasarnya. Semua jenis dan penyedia Wayang yang ada ditulis dalam bahasa Ruby. Karena mengikuti format pengkodean standar, seseorang dapat dengan mudah membuatnya seperti yang ditunjukkan pada contoh untuk repo yang mengelola repositori. Di sini, kita akan membuat repo tipe dan provider svn dan git. Bagian pertama dari tipe repo adalah tipe itu sendiri. Jenis biasanya disimpan di lib / puppet / type. Untuk ini, kami akan membuat file bernamarepo.rb.
$ touch repo.rb
Tambahkan konten berikut di file.
Puppet::Type.newtype(:repo) do
@doc = "Manage repos"
Ensurable
newparam(:source) do
desc "The repo source"
validate do |value|
if value =~ /^git/
resource[:provider] = :git
else
resource[:provider] = :svn
end
end
isnamevar
end
newparam(:path) do
desc "Destination path"
validate do |value|
unless value =~ /^\/[a-z0-9]+/
raise ArgumentError , "%s is not a valid file path" % value
end
end
end
end
Pada skrip di atas, kami telah membuat blok "Puppet::Type.newtype(:repo) do"yang membuat tipe baru dengan nama repo. Kemudian, kami memiliki @doc yang membantu dalam menambahkan tingkat detail apa pun yang ingin ditambahkan. Pernyataan berikutnya adalah Ensurable; ini membuat properti memastikan dasar. Jenis boneka menggunakan ensure properti untuk menentukan status item konfigurasi.
Contoh
service { "sshd":
ensure => present,
}
Pernyataan sure memberi tahu Puppet untuk kecuali tiga metode: buat, hancurkan, dan ada di penyedia. Metode ini menyediakan fitur-fitur berikut -
- Perintah untuk membuat sumber daya
- Perintah untuk menghapus sumber daya
- Perintah untuk memeriksa keberadaan sumber daya
Yang perlu kita lakukan adalah menentukan metode ini dan isinya. Wayang menciptakan infrastruktur pendukung di sekitar mereka.
Selanjutnya, kami mendefinisikan parameter baru yang disebut source.
newparam(:source) do
desc "The repo source"
validate do |value|
if value =~ /^git/
resource[:provider] = :git
else
resource[:provider] = :svn
end
end
isnamevar
end
Sumber akan memberi tahu tipe repo tempat untuk mengambil / menggandakan / memeriksa repositori sumber. Dalam hal ini, kami juga menggunakan hook yang disebut validate. Di bagian provider, kita telah mendefinisikan git dan svn yang memeriksa validitas repositori yang telah kita tentukan.
Terakhir, dalam kode kita telah mendefinisikan satu parameter lagi yang disebut path.
newparam(:path) do
desc "Destination path"
validate do |value|
unless value =~ /^\/[a-z0-9]+/
raise ArgumentError , "%s is not a valid file path" % value
end
Ini adalah tipe nilai yang menentukan di mana harus meletakkan kode baru yang diambil. Di sini, sekali lagi gunakan hook validasi untuk membuat blok yang memeriksa nilai kesesuaian.
Kasus Penggunaan Penyedia Subversion
Mari kita mulai dengan penyedia subversi menggunakan tipe yang dibuat di atas.
require 'fileutils'
Puppet::Type.type(:repo).provide(:svn) do
desc "SVN Support"
commands :svncmd => "svn"
commands :svnadmin => "svnadmin"
def create
svncmd "checkout", resource[:name], resource[:path]
end
def destroy
FileUtils.rm_rf resource[:path]
end
def exists?
File.directory? resource[:path]
end
end
Dalam kode di atas, kami telah menentukan dimuka yang kami butuhkan fileutils perpustakaan, membutuhkan 'fileutils' dari mana kita akan menggunakan metode.
Selanjutnya, kami telah mendefinisikan penyedia sebagai blok Puppet :: Type.type (: repo) .provide (: svn) do yang memberi tahu Puppet bahwa ini adalah penyedia untuk tipe yang disebut repo.
Kemudian, kami telah menambahkan descyang memungkinkan untuk menambahkan beberapa dokumentasi ke penyedia. Kami juga telah menentukan perintah yang akan digunakan penyedia ini. Di baris berikutnya, kami memeriksa fitur sumber daya seperti membuat, menghapus, dan ada.
Menciptakan Sumber Daya
Setelah semua hal di atas selesai, kami akan membuat sumber daya yang akan digunakan di kelas kami dan file manifes seperti yang ditunjukkan pada kode berikut.
repo { "wp":
source => "http://g01063908.git.brcl.org/trunk/",
path => "/var/www/wp",
ensure => present,
}