Size: 4621
Comment: /etc/hosts change is no longer required; rabbitfixture is more robust.
|
← Revision 113 as of 2021-12-10 15:20:27 ⇥
Size: 0
Comment: use LXD instead; see https://launchpad.readthedocs.io/en/latest/running.html
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
## page was copied from Running/VirtualMachine This page explains how to set up and run Launchpad (for development) inside a LXC. = Why? = Launchpad development setup makes significant changes to your machine; its nice to be unaffected by those except when you are actually doing such development. Also, launchpad has some limitations on concurrent testing per-machine and so forth - multiple container's can be used to work around this. = Make a LXC = 1. Install lxc {{{ sudo apt-get install lxc }}} 1. Work around Bug:800456 and Bug:801002 {{{ sudo apt-get install cgroup-bin libvirt-bin }}} 1. Work around Bug:784093 {{{ sudo dd of=/etc/cgconfig.conf << EOF mount { cpu = /sys/fs//cgroup/cpu; cpuacct = /sys/fs/cgroup/cpu; devices = /sys/fs/cgroup/cpu; memory = /sys/fs/cgroup/cpu; } EOF sudo service cgconfig restart }}} 1. Work around Bug:798476 (optional if you run i386 or have a -tonne- of memory and don't care about 64-bit footprint. Grab the patch from the bug and apply it to /usr/lib/lxc/templates/lxc-lucid. If you're running i386 already or want a 64-bit lxc then do not pass arch= on the lxc-create command line. 1. Create a config for your containers {{{ sudo dd of=/etc/lxc/local.conf << EOF lxc.network.type=veth lxc.network.link=virbr0 lxc.network.flags=up #fuse (workaround for Bug:800886) lxc.cgroup.devices.allow = c 10:229 rwm # part of the Bug:798476 workaround - # remove if you are running a 64 bit lxc or # 32 bit on 32-bit base os lxc.arch = i686 EOF }}} 1. Create a container {{{ sudo arch=i386 lxc-create -n lucid-test-lp -t lucid -f /etc/lxc/local.conf }}} If you want to use a proxy {{{ sudo arch=i386 http_proxy=http://host:port/ lxc-create -n lucid-test-lp -t lucid -f /etc/lxc/local.conf }}} And if you want to set a custom mirror, similar to http_proxy, but set MIRROR= instead. 1. (Outside the container) grab your user id and username so you can setup a bind mount outside the container: {{{ id -u id -nu }}} 1. Start the container {{{ sudo lxc-start -n lucid-test-lp }}} Ignore the warning about openssh crashing - it restarts on a later event. The initial credentials are root:root. 1. Grab the ip address (handed out via libvirt's dhcp server) - you may wish to ssh in rather than using the console (seems to have better termcap experience). {{{ ip addr show dev eth0 | grep 'inet' }}} 1. The new container won't have your proxy / mirror settings preserved. Customise it at this point before going further if you care about this. 1. Enable multiverse (rocketfuel-setup wants it, don't ask me why). 1. Install some additional packages we'll need to run rocketfuel-setup etc. {{{ apt-get install python-software-properties apt-add-repository ppa:ubuntu-virt apt-get update apt-get install bzr less sudo lxcguest # select I for 'install' when prompted about console.conf }}} 1. Inside the container add the user: {{{ adduser --uid $id $username adduser $username sudo }}} 1. To stop it now run 'poweroff -n' (normally you would use lxc-stop, but see Bug:784093). 1. Setup a bind mount so you can access your home dir (and thus your LP source code) from within the lxc container: * edit /var/lib/lxc/lucid-test-lp/fstab * Add a line: {{{ /home/$username /var/lib/lxc/lucid-test-lp/rootfs/home/$username none bind 0 0 }}} 1. Start it up again - headless now, we have the ip address from before. {{{ sudo lxc-start -n lucid-test-lp -d }}} 1. ssh <vm IP address> to connect to the VM. Your ssh key is already present because of the bind mount to your home dir. 1. You can now follow the [[Getting|getting-started]] on LP instructions. Be warned that changes in ~ will affect you outside the container. You will want to run rocketfuel-setup with --no-workspace if your home already has a workarea. You may need to run utilities/launchpad-database-setup separately too. 1. You probably want to follow [[Running/RemoteAccess]] has a discussion for how you can configure things so your non-container browser can access web pages from within the container. 1. rabbitmq may fail to start up. If that happens it appears to be a [[http://lists.rabbitmq.com/pipermail/rabbitmq-discuss/2010-April/007024.html|mnesia glitch]] best sorted by zapping mnesia. {{{ sudo rm -rf /var/lib/rabbitmq/mnesia/rabbit/* sudo service rabbit-mq start }}} = References = = Alternatively = You can also run in a [[Running/Schroot|chroot]] environment or a [[Running/VirtualMachine|VM]]. |