Hosting Your Portfolio Website for Free Using GitHub Pages
Why pay for servers when you can host websites for free with GitHub Pages?
data:image/s3,"s3://crabby-images/9d6bb/9d6bb5429946277eb15cfae9ebdbc3eb104bdcd8" alt="Warp Terminal"
Creating an online portfolio is a fantastic way to showcase your work, skills, and personal brand.
Fortunately, you don't need to be a web developer to get started, neither you need to spend money to host the server for your website.
GitHub Pages is a free and user-friendly platform that allows you to host your portfolio website directly from a GitHub repository.
Sounds exciting? In this tutorial, we’ll explore what GitHub Pages is, walk through creating a simple website and guide you on how to host it with your custom domain.
What are GitHub Pages?
GitHub Pages is a static site hosting service that takes files from a GitHub repository and serves them as a website. It's designed primarily for hosting personal, project, or organizational websites.
You can use HTML, CSS, and JavaScript to create your site. GitHub Pages supports custom domains, making it a flexible option for anyone looking to establish an online presence.
Key features of GitHub Pages
- Free Hosting: Host your website without incurring costs.
- Version Control: Leverage Git's version control features for your files.
- Custom Domains: Easily set up your own domain name.
- Jekyll Support: Utilize Jekyll, a static site generator, for more advanced setups.
Use a pre-designed template for your portfolio website
Okay, don’t judge me, I’m using a pre-built theme for this tutorial. But hey, it’s only because these themes are awesome and save a ton of time!
Of course, you can absolutely flex your creative muscles and design a jaw-dropping website from scratch if you want.
GitHub Pages works seamlessly with Jekyll, which offers an array of gorgeous themes to choose from.
Browse the Jekyll Themes directory
data:image/s3,"s3://crabby-images/c9d2e/c9d2e9591106740bdc43d8b97d87ccee04e440b4" alt="free jekyll themes directory"
And pick one that fits your taste:
data:image/s3,"s3://crabby-images/ce860/ce860916c91614aca46ec1b96e5fdc0478757474" alt="Im using Freelancer theme template"
Fork or download the theme’s repository:
data:image/s3,"s3://crabby-images/d56cc/d56ccc2ccf83934bafc0ff85efecb7c40234e17c" alt="downloading the jelyll theme from github in zip format"
yourname.github.io
or you can download it as a zip file and edit it locallyAnd start tweaking it to add your personality:
data:image/s3,"s3://crabby-images/9903a/9903a177a1dc9783c1352ba70ee6d1221339b897" alt="editing the template and adding own details"
Set up a GitHub repository
Create a GitHub Account: If you don’t have one, sign up at GitHub.
Create a new repository. Click on the “+” icon in the top-right corner and select “New repository.”
data:image/s3,"s3://crabby-images/076bb/076bbf56ac5838230697fc1e3e033c56befa7b32" alt="buttons to create a new repository"
Name your repository e.g., yourusername.github.io
and set it to public and click “Create repository.”
data:image/s3,"s3://crabby-images/bd6a5/bd6a5de11311f96dcf4ab56293706fa733576319" alt="creating a new repo for github pages"
Upload your website files
Go to your new repository and click on “Add file” > “Upload files.”
data:image/s3,"s3://crabby-images/ee60e/ee60eef53dac935fdc1dd97e397fcacfff2da13c" alt="add files menu"
Drag and drop your HTML files (and any additional files like CSS or images) that you downloaded with the theme and commit your changes.
data:image/s3,"s3://crabby-images/ea815/ea81560cba633ce9568a26587c4c9735583b7b2c" alt="adding files via upload and commiting the changes"
Enable GitHub Pages
In your repository, go to “Settings.” and Scroll down to the “Pages” section. Under “Source,” select the branch (main/ master) and click “Save.”
After a few moments, your website will be live at https://yourusername.github.io
.
data:image/s3,"s3://crabby-images/7b21e/7b21ea8f3f8e28928b085a517d276d8e50f3bb03" alt="enabling github pages from the settings"
Set up a custom domain
If you have a custom domain, you can link it to your GitHub Pages site:
In your repository settings, under “Pages,” add your personal domain in the “Custom domain” section and save.
data:image/s3,"s3://crabby-images/9f42c/9f42c3fb361e9d3d6d351810aaed1458ee7b0f52" alt="adding custom domain"
Add a CNAME record pointing to yourusername.github.io
data:image/s3,"s3://crabby-images/33d9f/33d9f3c6fa3818a5fc385f4d697cb4d01dbf2ebe" alt="changing dns settings and adding a cname record"
If you are using an apex domain (like example.com
), add an A record pointing to GitHub's IP addresses:
185.199.108.153
185.199.109.153
185.199.110.153
185.199.111.153
Verify your custom domain
After DNS propagation (which can take up to 48 hours), your custom domain should direct to your GitHub Pages site.
data:image/s3,"s3://crabby-images/85ce7/85ce76c832dd4ba207dbc0df9c9fddcb63f4f552" alt="our portfolio website is now live on our personal domain"
Conclusion
Hosting your portfolio website on GitHub Pages is a straightforward process that empowers you to showcase your skills and projects online.
With just a few steps, you can create and host a professional-looking site using HTML, customize it to fit your style, and even link it to a custom domain.
Start your journey today and present your work to the world with confidence! If you have any question, feel free to drop a comment below.
I'm definitely not a nerd, perhaps a geek who likes to tinker around with whatever tech I get my hands on. Figuring things out on my own gives me joy. BTW, I don't use Arch.