Chef-정의

정의는 반복적으로 사용되는 자원을 그룹화하는 논리적 방법으로 정의 할 수 있습니다. 이 흐름에서는 리소스를 그룹화하고 정의 된 쿡북을 다시 읽을 수 있도록 이름을 지정합니다.

이렇게하려면 레시피가 있어야합니다. 이 경우 test_cookbook과 쿡북이 포함 된 노드 실행 목록을 사용합니다.

정의 만들기

Step 1 − 쿡북 정의 폴더에 새 정의 파일을 생성합니다.

vipin@laptop:~/chef-repo $ subl cookbooks/test_cookbook/definitions/ 
capistrano_deploy_dirs.rb 
define :capistrano_deploy_dirs, :deploy_to => '' do 
   directory "#{params[:deploy_to]}/releases" 
   directory "#{params[:deploy_to]}/shared" 
   directory "#{params[:deploy_to]}/shared/system" 
end

Step 2 − 요리 책 기본 레시피 내에서 정의를 사용하십시오.

vipin@laptop:~/chef-repo $ subl cookbooks/test_cookbook/recipes/default.rb 
capistrano_deploy_dirs do 
   deploy_to "/srv" 
end

Step 3 − 요리사 서버에 요리 책을 업로드합니다.

vipin@laptop:~/chef-repo $ knife cookbook upload test_cookbook 
Uploading test_cookbook [0.1.0]

Step 4 − 원하는 노드에서 Chef 클라이언트를 실행하십시오.

vipin@laptop:~/chef-repuser@server $ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-01-18T16:31:11+00:00] INFO: Processing directory[/srv/ 
releases] action create (my_cookbook::default line 2) 
[2013-01-18T16:31:11+00:00] INFO: directory[/srv/releases] created 
directory /srv/releases 
[2013-01-18T16:31:11+00:00] INFO: Processing directory[/srv/ 
shared] action create (my_cookbook::default line 3) 
[2013-01-18T16:31:11+00:00] INFO: directory[/srv/shared] created 
directory /srv/shared 
[2013-01-18T16:31:11+00:00] INFO: Processing directory[/srv/ 
shared/system] action create (my_cookbook::default line 4) 
[2013-01-18T16:31:11+00:00] INFO: directory[/srv/shared/system]

요리 책의 정의는 리소스를 그룹화하고 이름을 부여하는 마이크로와 같습니다. 정의에는 레시피 내에서 호출 할 수있는 이름을 알려줄 수있는 이름이 있으며 경계 목록이 있습니다.

정의에는 코드에 다음과 같은 매개 변수가 있습니다.

….. 
directory "#{params[:deploy_to]}/releases" 
directory "#{params[:deploy_to]}/shared" 
directory "#{params[:deploy_to]}/shared/system” 
……

다음과 같이 기본 레시피 내에서 사용할 수 있습니다.

capistrano_deploy_dirs do 
   deploy_to "/srv"` 
end