阿里云部署博客hexo+git+nginx

部署环境:阿里云centos7.3,本地win10html

检查端口访问权限

实列列表->操做->更多->网络和安全组->安全组配置,点击配置规则,查看是否开放了400080端口node

没有配置的直接点击右上角的【添加安全组规则】便可,受权对象通常配置0.0.0.0/0,即对全部访问者开放。nginx

环境搭建

推荐直接使用命令安装,也能够去官网下载tar包而后解压。git

安装git

yum install git
复制代码

安装NodeJs

curl --silent --location https://rpm.nodesource.com/setup_10.x | bash -
sudo yum install -y nodejs
复制代码
  • 安装完成后,查看版本,确认安装成功
git --version
node --version
复制代码

环境部署与博客搭建

添加用户

adduser git
复制代码
  • 受权用户
chmod 740 /etc/sudoers
vim /etc/sudoers
复制代码
  • /Allow root定位到此处

  • 将给git添加到root下面
git ALL=(ALL) ALL
复制代码

  • :wq保存退出后,将权限改回
chmod 400 /etc/sudoers
复制代码

免密输入

  • 切换用户
sudo passwd git
复制代码
  • 为新用户建立密码后,考虑git的自动部署,开始为git授予ssh公钥实现免密输入
su git
mkdir ~/.ssh
vim ~/.ssh/authorized_keys
复制代码

电脑端操做(windows)

  • git-bash
ssh-keygen -t rsa
复制代码
  1. 键入这个命令后,会提示让你给这个公钥配置密码,咱们的目的就是免密登陆,不用理会,一路回车便可。npm

  2. 而后将win10中生成的id_rsa.pub文件中的公钥复制到authorized_keysvim

  3. 随后修改目录权限权限windows

chmod 600 ~/.ssh/authorized_keys
chmod 700 ~/.ssh
复制代码
  • 输入一次帐户密码,之后再链接SSH就能够免密登陆,直接在window远程操做
ssh -v git@服务器公网IP
复制代码

nginx安装配置

  • 回到root用户centos

  • 安装安全

su // 回到root
yum install nginx -y
复制代码
  • 启动
systemctl start nginx
systemctl enable nginx
复制代码
  • 随后访问公网ip

  • 配置Nginx(若是有人是Welcome to nginx on Fedora!是没有该目录的,建议从新安装
vim /etc/nginx/conf.d/default.conf
复制代码
  • 修改域名和目录

  • 建立对应的目录
sudo mkdir -p /usr/share/nginx/html/blog
sudo chown -R git:git /usr/share/nginx/html/blog
复制代码
  • 建立git仓库
su git
cd ~
git init --bare blog.git
复制代码
  • 建立一个新的 Git 钩子,用于自动部署在/blog.git 下,有一个自动生成的 hooks 文件夹。在里边新建一个新的钩子文件 post-receive
vim ~/blog.git/hooks/post-receive
复制代码
  • 编辑内容
#!/bin/sh
git --work-tree=/usr/share/nginx/html/blog --git-dir=/home/git/blog.git checkout -f
复制代码
  • 保存退出以后,再输入如下代码,赋予该文件可执行权限。
chmod +x ~/blog.git/hooks/post-receive
复制代码

博客与Hexo

Hexo是经常使用于搭建博客系统的框架,支持markdown编辑,可以实现博客的自动部署bash

安装Hexo

sudo npm install -g hexo-cli
复制代码
  • 建立文件夹,用于初始化Hexo及存放博客内容
mkdir ~/hexo
cd hexo
hexo init blog
复制代码
  • 初始化的Hexo即在blog文件夹中,包含配置_config.yml(核心配置),source(博客资源)等主要目录,
  • 接着安装必要插件
cd blog
npm install hexo-deployer-git --save
npm install hexo-server
复制代码

hexo-deployer-git用于Git自动部署,hexo-server用于本地简单的服务器。

  • 运行测试
hexo s -g
复制代码

  • 访问IP/域名:4000

这个是Hexo的默认主题,若是想换个主题。推荐使用Next主题,选择喜欢的主题后,里面的wiki有详细的主题配置教程。

  • ctrl+c中止刚才的hexo服务,而后初始化NodeJs
brew install nodejs
复制代码
  • 建立本身的第一篇博客 Hello World
hexo new "Hello Saturaday"
复制代码
  • 能够看到对应的Hello-Saturday .md已自动生成,咱们在里面写咱们的博客就能够了
vim source/_posts/Hello-Saturday.md
复制代码

  • 保存退出后,hexo s -g

  • 再次访问域名,就可看到新编辑的内容了

Hexo的后台运行脚本

按照上数部署后,虽然能够访问博客,可是一旦断开了链接,这个服务就中止了,所以须要编辑一个运行脚本,保持服务的运行。

  • 直接在blog的目录下,先建立启动脚本start.sh
vim start.sh
hexo s & > log.txt
:wq
chmod 777 start.sh
复制代码
  • 再建立run.sh运行脚本
vim run.sh
nohup ./start.sh 2> run.txt
:wq
chmod 777 run.sh
复制代码
  • 最后建立关闭stop.sh脚本
vim stop.sh
ID=`ps -ef | grep "hexo" | grep -v "grep" | awk '{print $2}'`
echo $ID
echo "---------------"
for id in $ID
do
kill -9 $id
echo "killed $id"
done
echo "---------------"
:wq
chmod 777 stop.sh
复制代码
  • 最后运行脚本便可
./run.sh
复制代码

注:偏于有限,可能不太详细,参考博文
相关文章
相关标签/搜索