Hexo博客部署到自己服务器

前言

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是否安装成功

nginx4.png

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

nginx5.png

重启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: [email protected]:/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防火墙配置

你可能感兴趣的:(Hexo博客部署到自己服务器)