前言
Hexo是一个好用的博客系统,网上很多都是把博客系统部署在GitHub上,但是在国内很多时候访问GitHub速度会很慢,阅读体验很不好,为了解决这个问题,我们可以将Hexo搭建到自己的服务器上,这样访问博客的速度就有了很大的提升!
服务器端
1.安装Nginx
1.登录通过ssh登录到服务器中,进入一个存放下载文件的目录
[root@bogon src]# cd /usr/local/src/
2.下载Nginx
[root@bogon src]# wget http://nginx.org/download/nginx-1.6.2.tar.gz
3.解压文件并进入该文件
[root@bogon src]# tar zxvf nginx-1.6.2.tar.gz
[root@bogon src]# cd nginx-1.6.2
4.编译安装
[root@bogon src]# ./configure --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/src/pcre-8.35
[root@bogon src]# make
[root@bogon src]# make install
5.安装完成
cd ~
返回根目录
/usr/local/webserver/nginx/sbin/nginx -v
查看Nignxi是否安装成功
2.配置Git环境
添加Git用户
yum install -y nginx git #安装git
useradd git #添加Git用户
passwd git #设置Git登录密码
chmod 740 /etc/sudoers # 给git用户配置sudo权限
vim /etc/sudoers
# 找到root ALL=(ALL) ALL,在它下方加入一行
git ALL=(ALL) ALL
chmod 400 /etc/sudoers #给sudo配置权限
给Git用户添加ssh秘钥用于免密码登录
Git生成SSH Key
sudo ssh-keygen -t rsa -C "e-mail地址"
回车后提示输入密码,此处密码可以不填, 直接回车,提示再次输入密码, 直接回车,生成成功
查看电脑上的SSH key
cat ~/.ssh/id_rsa.pub
su - git #切换到git用户
mkdir -p ~/.ssh #新建一个.ssh文件夹
touch ~/.ssh/authorized_keys #新建一个.authorized_keys
chmod 600 ~/.ssh/authorzied_keys #该权限是保证git用户免密登录推送文件必要步骤
chmod 700 ~/.ssh
vim ~/.ssh/authorized_keys #将电脑上的ssh密钥粘贴进去
创建Git仓库并使用Git-hooks实现自动部署
sudo mkdir -p /var/repo #新建目录,这是git仓库的位置
sudo mkdir pp /var/www/hexo
cd /var/repo #转到git仓库的文件夹
sudo git init --bare blog.git #创建一个名叫blog的仓库
sudo vim /var/repo/blog.git/hooks/post-update
# post-update的内如如下:
#!/bin/bash
git --work-tree=/var/www/hexo --git-dir=/var/repo/blog.git checkout -f
#给post-update授权:
cd /var/repo/blog.git/hooks/
sudo chown -R git:git /var/repo/
sudo chown -R git:git /var/www/hexo
sudo chmod +x post-update #赋予其可执行权限
3.配置Nginx
1.使用vim打开nginx配置目录
vim usr/local/webserver/nginx/conf/nginx.conf
# 如果需要https则把注释打开
server {
listen 80;
server_name www.test.com; #填写自己域名
#listen 443 ssl;
#ssl_certificate /usr/local/webserver/nginx/ssl/dramcl.cn.crt;
#ssl_certificate_key /usr/local/webserver/nginx/ssl/dramcl.cn.key;
#ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
#ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
#ssl_prefer_server_ciphers on;
#ssl_session_timeout 10m;
#ssl_session_cache builtin:1000 shared:SSL:10m;
#ssl_buffer_size 1400;
#ssl_stapling on;
#ssl_stapling_verify on;
index index.html index.htm index.php;
root /var/www/hexo; #站点目录
}
检查Nginx配置文件
/usr/local/webserver/nginx/sbin/nginx -t
重启Nginx
/usr/local/webserver/nginx/sbin/nginx -s reopen
本地配置
1.安装Git
xcode-select --install
git --version
git version 2.21.1 (Apple Git-122.3)
2.安装Node.js和Npm
# 安装brew
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
#通过brew安装Node 也可以去Node.js官网安装
sudo brew install node sudo
node -v #查看node版本
npm -v #查看npm版本
3.安装Hexo及相关插件
sudo npm install hexo-cli hexo-server hexo-deployer-git -g
hexo init ~/blog
npm install hexo-deployer-git --save
4.配置Hexo
# 修改Hexo的deploy配置
cd blog
vim _config.yml
# 找到deploy配置部分
# Deployment
## Docs: https://hexo.io/docs/deployment.html
deploy:
type: git
repo: root@xxx.xx.xxx.xxx:/var/repo/blog.git # IP填写自己服务器的IP即可
branch: master
5.将本地Hexo代码部署到服务器
# 清除缓存
hexo clean || hexo c
# 生成静态页面
hexo generate || hexo g
# 将本地静态页面目录推动到部署到云服务器
hexo delopy || hexo d
6.测试访问
访问相应的域名即可打开博客
服务器后台配置
这里以腾讯云为例
- 通过域名访问要在控制台为该域名添加解析
- 如果要使用https访问域名需要去备案,如果不备案可能会访问不了
- 去控制台的安全策略中添加443的访问权限,选择默认即可
- 如果以上都配置好的https还是无法访问可以配置下nginx的iptables防火墙配置