How to Use Jenkins - A Basic Approach
Deploy your Jenkins instance first.
We are going to use password login for automatic deployment, note that it’s not the most secure way, but for simplicity for now.
CHANGE SSH PORT - FOR DESTINATION SERVER
|  |  | 
Find out the line #port 22 and uncomment it to change into port ${YOUR_NEW_SSH_PORT}, then reload the sshd service like so:
|  |  | 
One more additional step for firewall (ufw in Ubuntu, firewall-cmd in CentOS), but we will refer to tons of materials out there, instead of mentioning it here.
ENABLE PASSWORD LOGIN FOR DESTINATION SERVER
In the same file as just above (/etc/ssh/sshd_config), do some modification like so:
|  |  | 
CREATE A PUBLIC KEY - FOR DESTINATION SERVER
Now you are seeing a public key of the destination server, which is called Deploy Key in Settings section on your github repo.
I believe you got some sense on how to use it now.
CREATE A JENKINS JOB
You need SSH plugin besides the preinstalled recommended plugins in your Jenkins plugin shed.
Pretty straightforward hereafter, once you know shell script, you will get things done smoothly.
CONFIGURE GITHUB HOOK TRIGGER FOR GIT-SCM POLLING
Navigate to your github repo’s Settings page, in the Webhooks tab, add in this url for Payload URL.
|  |  | 
And set the payload type to application/json.
Note that this is specific to Github plugin, which is automatically installed as a recommended one.
Now you have everything needed for setting up a basic CD pipeline using Jenkins.
Feel free to ask for help in case you got stuck. 😎
Thanks for reading!