Tony, When I explicitly specify --environment=production, Puppet breaks the same way as in the OP -- i.e. it simply fails to find the modules (and manifests). If I specify a non-existent environment, it throws the normal 'could not find directory environment' error.
So clearly Puppet reads my environments -- it just doesn't read anything *within *them, modules or manifests. It also doesn't read my environments/production/environment.conf file, which I just created: [root@kmadmin102 puppet]# ls -l /etc/puppet/environments/production/ total 12 -rw-r--r-- 1 root root 57 Oct 28 13:39 environment.conf drwxr-xr-x 3 root root 4096 Oct 24 15:20 manifests drwxr-xr-x 32 root root 4096 Oct 22 14:51 modules [root@kmadmin102 puppet]# cat /etc/puppet/environments/production/environment.conf modulepath = /etc/puppet/environments/production/modules [root@kmadmin102 puppet]# ls -m -w 80 /etc/puppet/environments/production/modules apache, apt, awstats, concat, elasticsearch, firewall, gcc, git, inifile, java, km, logrotate, memcached, module_data, mysql, nodejs, perl, php, postgresql, puppet-puppetdbquery, rclocal, redis, repoforge, rsync, src, stdlib, sudo, sysctl, wget, xinetd [root@kmadmin102 puppet]# puppet module list --environment=production /usr/share/puppet/modules (no modules installed) Thanks for the pointer about the default manifest, I didn't realize that it would actually override the environment ones, I assumed it worked additively, like modulepath. I have disabled the default manifest, but my puppet is still not finding the per-environment modules... On Tuesday, October 28, 2014 1:08:11 PM UTC-4, Tony Thayer wrote: > > What happens when you run > puppet module list --environment=production > ? > Your configuration doesn't define which environment the puppet agent lives > in, so it _should_default to production but I've been running into this > kind of thing myself. This directory structure is working for me: > /etc/puppet > - /modules (root modules, stuff downloaded from puppet forge) > - /manifests (Empty on purpose. Directory environments define my nodes now > .) > - /environments > - /test01 > - /test02 > - /manifests > - site.pp > - /modules > - /allmyenvironment-specific-modules > - /hieradata > - /production > - /manifests > - site.pp > - /modules > - /allmyenvironment-specific-modules > - /hieradata > > Specifying your default_manifest will override your directory environments > as per the documentation. My puppet.conf has some lines like this in it to > remind me: > > [main] > # The Puppet log directory. > # The default value is '$vardir/log'. > logdir = /var/log/puppet > > > # Where Puppet PID files are kept. > # The default value is '$vardir/run'. > rundir = /var/run/puppet > > > # Where SSL certificates are kept. > # The default value is '$confdir/ssl'. > ssldir = $vardir/ssl > environmentpath = $confdir/environments > basemodulepath = $confdir/modules > # default manifest prevents the directory environment from taking > # default_manifest = /etc/puppet/manifests > # Disabling to enable environment-specific site.pp 10/20/2014 tthayer > # disable_per_environment_manifest = true > > - Tony > > On Monday, October 27, 2014 2:43:07 PM UTC-7, Victor Danilchenko wrote: >> >> Hi all, >> >> I am running a puppetmaster setup on CentOS. We have out production >> environment working fine. However, I am trying to migrate from puppet 3.4, >> and from config environments to directory environments. I got my >> environments tree all set up in the puppet master, but when I activate my >> directory environments, puppetmaster suddently can't see any modules or >> manifests -- it runs, but returns empty catalog for the agent, and 'puppet >> modules list' says I have no modules installed: >> >> # puppet module list >> /usr/share/puppet/modules (no modules installed) >> >> None of the other global config files contain anything that references >> environments. My environment directory is set up correctly (it works on our >> production puppetmaster), and it works when I point the puppetmaster at it >> *explicitly*: >> >> # puppet module >> --confdir=/etc/puppet/environments/production/modules:/usr/share/puppet/modules >> >> list >> /etc/puppet/environments/production/modules >> >> ├── apache (???) >> ├── awstats (???) >> etc. >> >> Here's my main config file, stripped of comments: >> >> [main] >> certname=kmadmin102 >> dns_alt_names=kmadmin102.vistaprint.net,test-kmpuppet,test-kmpuppet. >> vistaprint.net,kmadmin102.vistaprint.net >> logdir = /var/log/puppet/ >> rundir = /var/run/puppet >> ssldir = $vardir/ssl >> pluginsync = true >> certificate_revocation = false >> report = false >> configtimeout = 4m >> *environmentpath **= $confdir/**environments* >> default_manifest = $confdir/manifests >> basemodulepath = $confdir/modules:/usr/share/puppet/modules >> [agent] >> classfile = $vardir/classes.txt >> localconfig = $vardir/localconfig >> [master] >> >> Can someone see what I am doing wrong? >> >> I also have PuppetDB installed, but that shouldn't affect 'puppet >> modules list' command. Puppet fails the same way with or without >> PuppetDB. >> > -- You received this message because you are subscribed to the Google Groups "Puppet Users" group. To unsubscribe from this group and stop receiving emails from it, send an email to puppet-users+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/puppet-users/ed5b5695-8356-47c9-bd0b-ceb35ad7d0d2%40googlegroups.com. For more options, visit https://groups.google.com/d/optout.