Javist being Cheftain
@ladislavGazo
gazo@seges.sk
Javist Part
Changelog
# change host records vim /etc/hosts vim /etc/hostname # optionally reboot reboot # to refresh repo list sudo apt-get update # to install updates sudo apt-get upgrade sudo apt-get install tmux mc
http://www.andrewault.net/2010/05/17/securing-an-ubuntu-server/ sudo sysctl -w net.ipv4.conf.all.accept_source_route=0 sudo sysctl -w net.ipv4.conf.default.accept_source_route=0 sudo aptitude -y install denyhosts sudo aptitude -y install tiger sudo aptitude -y install psad sudo chkrootkit
... but what if
- there are more servers
- change log for every one
- I want to setup development environment
- manually go through the changelog
- and probably do mistakes
- the changelog has some blank places
- usually it is not that detailed
Holy crap... now what?
Comparison?
Only subjective:
Chef feels more community friendly
&
I like community projects
Alternatives
Of course there are many:
- Puppet
- CFEngine
- Capistrano
- Fabric
- glu
- ...
There is a difference between infrastructure management and deployment management.
Chef Solo vs. Chef Server
Knife
Chef
Solo
- for local/one node
- no central repository of configuration
Server
- installed internally or bought from Opscode
- central repository of cookbooks
- easy to install on supported OS
- Ubuntu
Components
Components II.
attributes
run-lists
roles
data bags
environments
The Essence
Cookbooks:
Attributes
Recipes
Templates
Files
Metadata + Version + Dependencies
CookBooks
- managed by Knife
- source code stored in Git repository
- uploaded to the Chef Server
- downloaded by Chef Client on a particular Node
How to start Cooking?
You do not need to know Ruby up-front
=
wheew for Javist ;)
but
Next
Set up Git repo ( BB | GitHub | ... )
git clone git://github.com/opscode/chef-repo.git
Follow the guide precisely
Note: I keep separate user for development and separate for deployment
Write first CookBook
It is simple
knife cookbook create hyperic
cd hyperic
vim recipes/default.rb
you get along with 90% of what is already there for most recipes you are fine with basic programming techniques
kitchen init
testing is important
Testing
gem install test-kitchen --pre
gem install berkshelf
gem install kitchen-vagrant
SSH to running Vagrant machine when test-kitchen is executed
/chef-repo/cookbooks/hyperic/.kitchen/kitchen-vagrant/default-ubuntu-1204$ vagrant ssh
When everything is ready, "fire in the hole"
vim .kitchen.yml
kitchen test
Cache
http://fgrehm.viewdocs.io/vagrant-cachier
It saves time!
vagrant plugin install vagrant-cachier
But does not work with current Kitchen version without hacking configuration file
Notable Resources
directory "/tmp/folder" do
owner "root"
group "root"
mode 0755
action :create
end
user "hyperic" do
supports :manage_home => true
home "/home/#{hyperic_user}"
shell "/bin/bash"
action :create
end
remote_file "hyperic_bundle" do
path hyperic_src
owner hyperic_user
source node['hyperic']['agent']['bundle_url']
mode 00644
end
Other
template "/etc/init.d/#{service_name}" do
action :create_if_missing
owner "root"
mode 00700
source "hyperic-agent.erb"
variables(
:service_name => service_name,
:agentdir => hyperic_agentdir,
:user => hyperic_user,
:java_home => java_home
)
end
service service_name do pattern "agent-#{hyperic_version}"
action [ :enable, :start ]
end
bash "extract_tcc" do cwd ::File.dirname(tcc_down_path)
code <<-EOH
chown -R #{node.tcc.user}:#{node.tcc.group} #{node.tcc.location}
EOH
end
Notable Hints
- (re)create, not update
- rather don’t update file, find a way how to create it at once
- more detailed steps then you expected
- if you thought there are 10 steps what to execute in such an automated way in your head, there are 60 at least
- cookbook wrapper pattern
- describe the possibility to override resources in the “cookbook wrapper”
Questions?
@ladislavGazo
gazo@seges.sk
Thank YOu... for...
ATTENTION
Javist Being Cheftain
By lgazo
Javist Being Cheftain
An introduction to the automated infrastructure management with Chef for those who live (not exclusively) in the (Java) development world
- 931