matschaffer/knife-solo

berks upload fails with gem error on 0.10.0

janskarvall opened this issue · 15 comments

I am stuck with the error reported here: chef-boneyard/chef-dk#603. The error was not reported by me, but I have made a comment just stating that I get the same (or similar) error.

I was hoping that issue 603 was going to be fixed, but that issue is now closed without a fix.

So, I need advice on how to work around it.

I am experiencing the same issue, with a fresh instalation of chefdk 0.10.0-01.

How did you install knife & knife-solo? I suspect a fix would be to stick to only using chefdk and installing knife-solo via chef gem install knife-solo

Have you tried that approach?

Or if you're using a Gemfile locking it to berkshelf-4.0.1 & httpclient-2.7.0 might help.

Just to be sure, I made a fresh install of chef and knife-solo in a VirtualBox machine running an also fresh install of Ubuntu 14.04 LTS Desktop, 64-bit. I downloaded and installed the latest Chef 0.10.0-1 package (using Ubuntu Software Center which starts automatically after download). I also entered the 'eval "$(chef shell-init bash)"' line, not in ~/.bash_profile as the install guide says, as it is not run when starting a graphical terminal, but in ~/.profile), and checked that the path to ruby is set to /opt/chefdk/embedded/bin/ruby. Then I installed knife-solo with 'chef gem install knife-solo'.

I also have an old installation that I have been using, and that I have the original trouble with. I believe that the installations of chef and knife-sole are the same as on the VirtualBox, but I'm not 100 percent sure. One thing that differs is that I have also installed the Ruby package on that machine, but the path to ruby is the same, i.e. /opt/chefdk/embedded/bin/ruby. That installation has been working fine until, I think, I upgraded chef to 0.10.0. Then the problem occurred. I'm not sure if it is connected to the upgrade. If I remember right, I also made a 'berks update'.

In this old installation I have a lot of site-cookbooks that I rely on. I copied the whole cook-book structure to the VirtualBox installation (using rsync), and I get the same problem in the VirtualBox installation. I made 'berks update' on the VirtualBox machine too.

In both cases I target another, physical machine, the same in both cases.

I'm not using a Gemfile - I wouldn't know how to do that.

Thanks. I'm getting a little lost in all the permutations so I'll plan to
try with a fresh VM as well and send a vagrant file with results.

If you have specific commands you're using to get the issue let me know.

On Saturday, 6 February 2016, janskarvall notifications@github.com wrote:

Just to be sure, I made a fresh install of chef and knife-solo in a
VirtualBox machine running an also fresh install of Ubuntu 14.04 LTS
Desktop, 64-bit. I downloaded and installed the latest Chef 0.10.0-1
package (using Ubuntu Software Center which starts automatically after
download). I also entered the 'eval "$(chef shell-init bash)"' line, not in
~/.bash_profile as the install guide says, as it is not run when starting a
graphical terminal, but in ~/.profile), and checked that the path to ruby
is set to /opt/chefdk/embedded/bin/ruby. Then I installed knife-solo with
'chef gem install knife-solo'.

I also have an old installation that I have been using, and that I have
the original trouble with. I believe that the installations of chef and
knife-sole are the same as on the VirtualBox, but I'm not 100 percent sure.
One thing that differs is that I have also installed the Ruby package on
that machine, but the path to ruby is the same, i.e.
/opt/chefdk/embedded/bin/ruby. That installation has been working fine
until, I think, I upgraded chef to 0.10.0. Then the problem occurred. I'm
not sure if it is connected to the upgrade. If I remember right, I also
made a 'berks update'.

In this old installation I have a lot of site-cookbooks that I rely on. I
copied the whole cook-book structure to the VirtualBox installation (using
rsync), and I get the same problem in the VirtualBox installation. I made
'berks update' on the VirtualBox machine too.

In both cases I target another, physical machine, the same in both cases.

I'm not using a Gemfile - I wouldn't know how to do that.


Reply to this email directly or view it on GitHub
#476 (comment)
.

-Mat

matschaffer.com

I have never used vagrant, so I do not know what to get out of a vagrant file.

In order to assure that the problem is not connected to my cookbook structure, I made a very simple structure and tested:

janne@janne-VirtualBox:~/workspace/test$ cat nodes/192.168.0.182.json 
{
    "run_list": 
    [
        "recipe[test]"
    ]
}
janne@janne-VirtualBox:~/workspace/test$ cat site-cookbooks/test/recipes/default.rb 
file '/tmp/test' do
  content 'test'
end
janne@janne-VirtualBox:~/workspace/test$ cat site-cookbooks/test/metadata.rb 
name             'test'
maintainer       'YOUR_COMPANY_NAME'
maintainer_email 'YOUR_EMAIL'
license          'All rights reserved'
description      'Installs/Configures apptome-server'
long_description IO.read(File.join(File.dirname(__FILE__), 'README.md'))
version          '0.1.0'
janne@janne-VirtualBox:~/workspace/test$ cat Berksfile
source "https://supermarket.chef.io"
# metadata
janne@janne-VirtualBox:~/workspace/test$ knife solo cook 192.168.0.182
Running Chef on 192.168.0.182...
Checking Chef version...
janne@192.168.0.182's password: 
janne@192.168.0.182's password: 
Enter the password for janne@192.168.0.182: 
WARNING: #<Gem::ConflictError: Unable to activate berkshelf-4.0.1, because httpclient-2.7.0 conflicts with httpclient (~> 2.6.0)>
WARNING: Berkshelf could not be loaded
WARNING: Please add the berkshelf gem to your Gemfile or install it manually with `gem install berkshelf`
Uploading the kitchen...
janne@192.168.0.182's password: 
Generating solo config...
Running Chef: sudo chef-solo -c ~/chef-solo/solo.rb -j ~/chef-solo/dna.json

Starting Chef Client, version 12.5.1
Compiling Cookbooks...
Converging 1 resources
Recipe: test::default
  * file[/tmp/test] action create
    - create new file /tmp/test
    - update content in file /tmp/test from none to 9f86d0
    --- /tmp/test   2016-02-06 10:59:27.217874435 +0100
    +++ /tmp/.test20160206-19959-1rl5yyv    2016-02-06 10:59:27.217874435 +0100
    @@ -1 +1,2 @@
    +test

Running handlers:
Running handlers complete
Chef Client finished, 1/1 resources updated in 02 seconds
janne@janne-VirtualBox:~/workspace/test$ 

So, the warning that worries me is still there, and I don't know how to interpret it, but it sounds worrying.

I got exact same error.

I do not run in a VM. I am on a fresh Ubuntu 15.10 install (ruby is not installed) with a fresh chefdk install. Knife solo have been installed via:
chef gem install knife-solo

What is strange is that I am experiencing the same problem on an older installation which used to work, and, AFAIR, no update of chefdk or knife-solo has been made since then.

These warnings result in problems with finding my recipes.

I'm not sure how Berkshelf should work, but I have problems getting berks update to work properly.

janne@janne-VirtualBox:~/workspace/chef-repo$ berks update
/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/httpclient-2.6.0.1/lib/httpclient/webagent-cookie.rb:458: warning: already initialized constant HTTPClient::CookieManager
/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/httpclient-2.6.0.1/lib/httpclient/cookie.rb:8: warning: previous definition of CookieManager was here
Resolving cookbook dependencies...
(lines removed)
Using firewall (2.4.0)
(lines removed)
janne@janne-VirtualBox:~/workspace/chef-repo$

The warnings are discussed in Berks install warnings after ChefDK 0.10.

So, firewall is resolved to version 2.4.0. However, looking at the downloaded firewall metadata, I get:

janne@janne-VirtualBox:~/workspace/chef-repo$ head cookbooks/firewall/metadata.json 
{"name":"firewall","version":"1.6.1", (text deleted)

So berks update fails to update the cookbook. Compare with firewall/metadata.rb.

I don't know if berks update also should delete a cookbook from the cookbooks directory if you delete that cookbook from Berksfile. Anyway, it does not.

I suspect that berks update does update the cookbooks in ~/.berkshelf/cookbooks/ rather than in the expected place, i.e. in my case ~/workspace/chef-repo/cookbooks. I have not found out why yet.

I'm totally lost. I think I got the ~/workspace/chef-repo/.chef/knife.rb file by cloning chef/chef-repo a long time ago. Having a look there, that repository now seems to be deprecated, and one refers to chef generate repo command. Looking at chef (executable) I don't find any documentation about that command. However, I can run it:

janne@janne-VirtualBox:~/workspace$ chef generate repo x
Compiling Cookbooks...
Recipe: code_generator::repo
  * directory[/home/janne/workspace/x] action create
    - create new directory /home/janne/workspace/x
  * template[/home/janne/workspace/x/LICENSE] action create_if_missing
    - create new file /home/janne/workspace/x/LICENSE
    - update content in file /home/janne/workspace/x/LICENSE from none to f750c0
    (diff output suppressed by config)
  * cookbook_file[/home/janne/workspace/x/.chef-repo.txt] action create_if_missing
    - create new file /home/janne/workspace/x/.chef-repo.txt
    - update content in file /home/janne/workspace/x/.chef-repo.txt from none to 2bed28
    (diff output suppressed by config)
  * cookbook_file[/home/janne/workspace/x/README.md] action create_if_missing
    - create new file /home/janne/workspace/x/README.md
    - update content in file /home/janne/workspace/x/README.md from none to 1b81aa
    (diff output suppressed by config)
  * cookbook_file[/home/janne/workspace/x/chefignore] action create_if_missing
    - create new file /home/janne/workspace/x/chefignore
    - update content in file /home/janne/workspace/x/chefignore from none to 51b09a
    (diff output suppressed by config)
  * remote_directory[/home/janne/workspace/x/cookbooks] action create_if_missing
    - create new directory /home/janne/workspace/x/cookbooks
  Recipe: <Dynamically Defined Resource>
    * directory[/home/janne/workspace/x/cookbooks/example] action create
      - create new directory /home/janne/workspace/x/cookbooks/example
      - change mode from '' to '0775'
      - change owner from '' to 'janne'
      - change group from '' to 'janne'
    * cookbook_file[/home/janne/workspace/x/cookbooks/example/README.md] action create_if_missing
      - create new file /home/janne/workspace/x/cookbooks/example/README.md
      - update content in file /home/janne/workspace/x/cookbooks/example/README.md from none to d6634d
      (diff output suppressed by config)
      - change mode from '' to '0644'
    * cookbook_file[/home/janne/workspace/x/cookbooks/example/metadata.rb] action create_if_missing
      - create new file /home/janne/workspace/x/cookbooks/example/metadata.rb
      - update content in file /home/janne/workspace/x/cookbooks/example/metadata.rb from none to f0778c
      (diff output suppressed by config)
      - change mode from '' to '0644'
    * directory[/home/janne/workspace/x/cookbooks/example/recipes] action create
      - create new directory /home/janne/workspace/x/cookbooks/example/recipes
      - change mode from '' to '0775'
      - change owner from '' to 'janne'
      - change group from '' to 'janne'
    * cookbook_file[/home/janne/workspace/x/cookbooks/example/recipes/default.rb] action create_if_missing
      - create new file /home/janne/workspace/x/cookbooks/example/recipes/default.rb
      - update content in file /home/janne/workspace/x/cookbooks/example/recipes/default.rb from none to fec476
      (diff output suppressed by config)
      - change mode from '' to '0644'
    * directory[/home/janne/workspace/x/cookbooks/example/attributes] action create
      - create new directory /home/janne/workspace/x/cookbooks/example/attributes
      - change mode from '' to '0775'
      - change owner from '' to 'janne'
      - change group from '' to 'janne'
    * cookbook_file[/home/janne/workspace/x/cookbooks/example/attributes/default.rb] action create_if_missing
      - create new file /home/janne/workspace/x/cookbooks/example/attributes/default.rb
      - update content in file /home/janne/workspace/x/cookbooks/example/attributes/default.rb from none to 16a397
      (diff output suppressed by config)
      - change mode from '' to '0644'

Recipe: code_generator::repo
  * remote_directory[/home/janne/workspace/x/data_bags] action create_if_missing
    - create new directory /home/janne/workspace/x/data_bags
  Recipe: <Dynamically Defined Resource>
    * cookbook_file[/home/janne/workspace/x/data_bags/README.md] action create_if_missing
      - create new file /home/janne/workspace/x/data_bags/README.md
      - update content in file /home/janne/workspace/x/data_bags/README.md from none to 3167c5
      (diff output suppressed by config)
      - change mode from '' to '0644'
    * directory[/home/janne/workspace/x/data_bags/example] action create
      - create new directory /home/janne/workspace/x/data_bags/example
      - change mode from '' to '0775'
      - change owner from '' to 'janne'
      - change group from '' to 'janne'
    * cookbook_file[/home/janne/workspace/x/data_bags/example/example_item.json] action create_if_missing
      - create new file /home/janne/workspace/x/data_bags/example/example_item.json
      - update content in file /home/janne/workspace/x/data_bags/example/example_item.json from none to 1048ec
      (diff output suppressed by config)
      - change mode from '' to '0644'

Recipe: code_generator::repo
  * remote_directory[/home/janne/workspace/x/roles] action create_if_missing
    - create new directory /home/janne/workspace/x/roles
  Recipe: <Dynamically Defined Resource>
    * cookbook_file[/home/janne/workspace/x/roles/README.md] action create_if_missing
      - create new file /home/janne/workspace/x/roles/README.md
      - update content in file /home/janne/workspace/x/roles/README.md from none to 7a28c9
      (diff output suppressed by config)
      - change mode from '' to '0644'
    * cookbook_file[/home/janne/workspace/x/roles/example.json] action create_if_missing
      - create new file /home/janne/workspace/x/roles/example.json
      - update content in file /home/janne/workspace/x/roles/example.json from none to 297ea8
      (diff output suppressed by config)
      - change mode from '' to '0644'

Recipe: code_generator::repo
  * remote_directory[/home/janne/workspace/x/environments] action create_if_missing
    - create new directory /home/janne/workspace/x/environments
  Recipe: <Dynamically Defined Resource>
    * cookbook_file[/home/janne/workspace/x/environments/README.md] action create_if_missing
      - create new file /home/janne/workspace/x/environments/README.md
      - update content in file /home/janne/workspace/x/environments/README.md from none to c9ccdf
      (diff output suppressed by config)
      - change mode from '' to '0644'
    * cookbook_file[/home/janne/workspace/x/environments/example.json] action create_if_missing
      - create new file /home/janne/workspace/x/environments/example.json
      - update content in file /home/janne/workspace/x/environments/example.json from none to 59a963
      (diff output suppressed by config)
      - change mode from '' to '0644'

Recipe: code_generator::repo
  * cookbook_file[/home/janne/workspace/x/cookbooks/README.md] action create_if_missing
    - create new file /home/janne/workspace/x/cookbooks/README.md
    - update content in file /home/janne/workspace/x/cookbooks/README.md from none to 86e9ef
    (diff output suppressed by config)
  * execute[initialize-git] action run
    - execute git init .
  * template[/home/janne/workspace/x/.gitignore] action create_if_missing
    - create new file /home/janne/workspace/x/.gitignore
    - update content in file /home/janne/workspace/x/.gitignore from none to 3523c4
    (diff output suppressed by config)
janne@janne-VirtualBox:~/workspace$ cd x
janne@janne-VirtualBox:~/workspace/x$ ls -a
.   chefignore      cookbooks  environments  .gitignore  README.md
..  .chef-repo.txt  data_bags  .git          LICENSE     roles
janne@janne-VirtualBox:~/workspace/x$

But there is neither ~/workspace/x/.chef/knife.rb file or a ~/workspace/x/.chef/config.rb file generated. Also, the Chef documentation about those files don't mention the knife[:berkshelf_path] = "cookbooks" configuration that I have in my ~/workspace/chef-repo/.chef/knife.rb file.

So, I can not understand how berks get to know where to put the downloaded cookbooks.

@janskarvall I tried this out this morning, here's the result:

https://gist.github.com/matschaffer/b386abcc1d88863dcc5a

Looks like knife-solo's berkshelf integration is no longer chefdk-compatible as of 0.10.0.

I'll file another ticket referencing this one. In the mean time the best resolutions I can offer is downgrading to chefdk 0.9.0, or using ruby directly and locking gem versions via bundler.

I have tried to find out if it is time to upgrade Chef DK.

I am currently using chefdk 0.9.0-1 together with knife-solo 0.5.1 on my Ubuntu 14.04 LTS client, targeting a Ununtu 16.04 LTS server without problems.

On the client (DK) side is seems that Chef is not yet promising that it runs om Ubuntu 16.04, so maybe I have to wait before upgrading the client (DK) machine to Ubuntu 16.04, but I wonder if it is possible to upgrade Chef-DK and knife-solo on that machine, and if so, to what versions.

Chef DK's latest version seems to be 0.15.16 right now.

Should chef 0.15.16 work together with knife-solo 0.6.0 (which seems to require chef >= 10.20) on my Ubuntu 14.04 machine?

Pretty sure all the latest releases should work together, and ubuntu 14.04 is recent enough so I'd recommend giving it a try. Note that the chef requirement in knife-solo is to https://rubygems.org/gems/chef (currently 12.12.15), not Chef DK.

If you hit a particular error let me know and I can try to test out your scenario on VMs.

I successfully cooked my Ununtu 16.04 LTS server using Chef DK 0.15.16 and knife-solo 0.6.0 from my Ubuntu 14.04 client.

When running chef gem list chef I however get chef (12.11.18).

Should I worry about that?

I wouldn't. :) good to hear it's working.

That's close enough to the latest that you shouldn't see any functionality
difference.

Could be the chef omnibus packages (what knife-solo will use on Ubuntu by
default) haven't been updated yet.

On Wednesday, 20 July 2016, janskarvall notifications@github.com wrote:

I successfully cooked my Ununtu 16.04 LTS server using Chef DK 0.15.16 and
knife-solo 0.6.0 from my Ubuntu 14.04 client.

When running chef gem list chef I however get chef (12.11.18).

Should I worry about that?


You are receiving this because you modified the open/close state.
Reply to this email directly, view it on GitHub
#476 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAACsirdoqweZLrCBQbg8rwZh4Bc8yJkks5qXf7mgaJpZM4HUPyO
.

-Mat

matschaffer.com

I downloaded Chef-DK 0.15.16 using this link and installed it using Ubuntu Software Center on my Ubuntu 14.04 LTS Desktop 64 bit client.