Installing And Configuring Propagator: Part 2

So now that our set up is ready, we have the master server and two mirror servers. And before proceeding any further I Strongly suggest you to go through the README section in this link  https://github.com/KDE/propagator and if you feel like you can come back .

1.Foremost you need to have the following installed in you master server :

  • Python 3.5
  • RabbitMQ
  • Celery 3
  • GitPython : make sure first you install pip3 using sudo apt-get install python3-pip then you can pip3 install gitpython
  • Supervisord
  • Propagator uses the AsyncIO module : pip3 install asyncio
  • Other dependencies : pip3 install requests                           

NOTE : Also install pip3 and Gitpython in the two mirror servers as well.

2. Install propagator in the master VM for that first you need to clone it                                     git clone https://github.com/KDE/propagator.git and then configure the ~/propagator/config/ServerConfig.json  for that first you need to change the RepoRoot to the location you have stored the git repository. Export the variable GATOR_CONFIG_FILE in bash for that run the command  export GATOR_CONFIG_FILE=/path_to_propagator/config/ServerConfig.json          Then you can run the server with the command  supervisord -c ./supervisord.conf 

Screenshot from 2016-05-16 17-43-15

3.Setting up the AnongitRemote plugin to push to the two mirror servers :

  • First we generate a new SSH key in the master VM and make sure you store it somewhere else not ~/.ssh so that now we have two SSH keys on the server the old one is already in use so we keep it untouched now that we have a new SSH key we append the public key to the ~/.ssh/authorized_keys on the master server and configure the ~/propagator/config/ServerConfig.json  by setting the path of the private key in the field AnongitAPIKeyFile .And then we copy this public key to the two mirrors  with the command ssh-copy-id -i ~/path_to_new_sshkey/id_rsa.pub user@IP
  • Then we copy the agent/GatorSSHAgent from the master VM to the two mirror server, run this in the master VM                                                                                                scp /path_to_propagator/agent/GatorSSHAgent user@IP:/destination                         here user and IP are of the mirror VM and destination is the location you want to store it in mirror. Make sure you have installed pip3 and GitPython in the mirrors as well.
  • Now configure the ~/.ssh/authorized_keys file of the two mirrors. Note that the second ssh-rsa key is the newly copied key so we need to prefix the second key and it will look like  command=path/to/GatorSSHAgent ssh-rsaAcd ……..fddhg@ssh-key-comment

4. Lastly we need to edit the post-update hook of the git repository in the master server where we specify the location of mirrorctl in master server and the loacation of the git repo in mirror servers so add this command /path_to_propagator/bin/mirrorctl update user@IP:/location_of_git_repo name_of_repo.git                

DEBUGGING :

Please make sure you use Python 3 throughout as Propagator is written in Python3.5 if you get any errors during running it that means some modules you installed is not Python 3 compatible.All you need to do is to check the log files and run the modules in server separately eg : python3 CeleryWorkers.py  and in case you get errors debug accordingly. If you feel that the server is still not working delete /home/user/.propagator.sock and then try to run propagator again.

 

Advertisements

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / Change )

Twitter picture

You are commenting using your Twitter account. Log Out / Change )

Facebook photo

You are commenting using your Facebook account. Log Out / Change )

Google+ photo

You are commenting using your Google+ account. Log Out / Change )

Connecting to %s