Github deploy to server

Github deploy to server

This tutorial will show you how to deploy from GitHub to your server using GIT. Deploying with GIT makes it possible to automatically have your server updated every time you commit to GitHub.

Connect to your server

First SSH into your server:

ssh username@domain.com -p 7822 (the 7822 is the port number and may be different on your server)

Go to the directory when you want to have the GitHub repo deployed to. Next get the GitHub ssh url from the GitHub project it will be like github.com/username/project.git

To clone the repo type

git clone https://github.com/username/project.git

On the first time you may get this warning:

The authenticity of host 'github.com' can't be established.
RSA key fingerprint is b6:03:0e:39:97:9e:d0:e7:24:ce:a3:77:3e:01:42:09.
Are you sure you want to continue connecting (yes/no)?

Enter yes, next you will get:

Warning: Permanently added 'github.com' (RSA) to the list of known hosts.
Connection closed
fatal: The remote end hung up unexpectedly

Now trying to do a git clone again results in the error:

Initialized empty Git repository in /home/username/public_html/project/.git/
Permission denied (publickey).
fatal: The remote end hung up unexpectedly

The reason for this is the server has not been authenticated again.

Create a public/private key

To get setup follow these steps:

type

ssh-keygen

The output:

Generating public/private rsa key pair.
Enter file in which to save the key (/home/username/.ssh/id_rsa):

Press enter to accept the default path

Enter passphrase (empty for no passphrase):

Press enter to accept no password or enter a password first.

The response will look something like:

The key's randomart image is:
+--[ RSA 2048]----+
|        .. .  .oB|
|       . .. + .++|
|        . o. o...|
|         o   .   |
|        S   .. . |
|           o. o  |
|          o..+   |
|          ....o  |
|           oE.   |
+-----------------+

Get the public key:

Go to .ssh folder

cd ~/.ssh

Open id_rsa.pub in vim

vi id_rsa.pub

Copy the full key. To exit vim press : then type wq

On GitHub go to Settings -> Deploy Keys → Add Deploy Keys

Add a title this is a reference so it can be anything then copy the key into the key box.

Now you should be all set up so once again go to where you want the repo to be pulled into and again type 

git clone https://github.com/username/project.git

the output will be:

initialized empty Git repository in /home/username/public_html/project/.git/
remote: Counting objects: 3048, done.
remote: Compressing objects: 100% (2125/2125), done.
remote: Total 3048 (delta 688), reused 2994 (delta 648)
Receiving objects: 100% (3048/3048), 9.83 MiB | 5.81 MiB/s, done.
Resolving deltas: 100% (688/688), done.

This will create a directory and pull in the repo contents.

Now anytime you want to update go into the directory and type 

git pull

Automatically Deploy 

To get git pull to run on the server every time there is a commit, can be achieved by using Webhooks.

On GitHub go to Settings -> Webhooks → Add Webhook

Enter a url to your server and a file to handle the webhook for this tutorial I will create a file called github.php to the url will be example.com/github.php

Enter your url tick just the push event and click Add Webook.

Now head over to your server and create a php file on the server.

touch github.php (you can name it anything but it much match the webhook on GitHub)

As the file created won’t have the right permissions change it with chmod

chmod 644 github.php

Now edit the file with vim:

vi github.php

Press i to go into edit mode

Type:

<?php `git pull`

Then press escape to go into read mode then save and exit by pressing : then type wq and enter.

By using backticks in the file the server will treat the file as a bash script. 

Alternatively, you can use system_exec(‘git pull’)

Now make a change on GitHub and the change will be pushed to your server automatically.

Did you find this article valuable?

Support David Carr by becoming a sponsor. Any amount is appreciated!