如何将博客部署到云服务器

经过我的一番研究,终于成功将博客部署的自己的服务器而不是依赖于github或者gite了,现在来一期域名购买到服务器配置到博客部署的教程。目前用的是阿里云。

视频教程

1.安装nginx

安装ngin需要相关的依赖库,我们先进行库的安装。

1.1安装gcc gcc-c++

1
2
3

yum install -y gcc gcc-c++

1.2安装PCRE库

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

cd /usr/local/

wget http://downloads.sourceforge.net/project/pcre/pcre/8.37/pcre-8.37.tar.gz

tar -xvf pcre-8.37.tar.gz

cd pcre-8.37

./configure

make && make install

pcre-config --version

1.3安装 openssl 、zlib 、 gcc 依赖

1
2
3

yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel

1.4安装nginx

安装nginx一定要在local文件夹下

1
2
3
4
5
6
7
8
9
10
11
12
13

cd /usr/local/

wget http://nginx.org/download/nginx-1.17.9.tar.gz

tar -xvf nginx-1.17.9.tar.gz

cd nginx-1.17.9

./configure

make && make install

修改配置文件server 80 端口下的root项 为/home/www/website;

2.安装Git以及Node.js

2.1安装Node.js

1
2
3
4
5

curl -sL https://rpm.nodesource.com/setup_10.x | bash -

yum install -y nodejs

查看是否成功

1
2
3
4
5

node -v

npm -v

可以显示版本号即为成功

2.2安装Git及配置仓库

安装git及新建git用户

1
2
3
4
5
6
7
8
9

yum install git

adduser git

chmod 740 /etc/sudoers

vi /etc/sudoers

在如下位置添加
git ALL=(ALL) ALL
vi指令执行之后按i进入输入模式
编辑完成之后按一下esc
然后输入:wq即可退出

执行以下指令更改文件夹权限

1
2
3
4
5

chmod 400 /etc/sudoers

sudo passwd git

切换git用户并且建立密钥

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

su git

cd ~

mkdir .ssh

cd .ssh

vi authorized_keys

chmod 600 ~/.ssh/authorized_keys

chmod 700 ~/.ssh

创建git仓库

1
2
3
4
5
6
7

cd ~

git init --bare blog.git

vi ~/blog.git/hooks/post-receive

输入

1
git --work-tree=/home/www/website --git-dir=/home/git/blog.git checkout -f

保存退出

1
2
chmod +x ~/blog.git/hooks/post-receive

*以上指令都需要在su git 之后执行 如果中途断开重新连接过,需要重新执行 su git指令 进入git账户。

新建/home/www/website文件夹
在root用户下执行,所限先su root切换为root账户

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

su root

输入密码

cd /home

mkdir www

cd www

mkdir website

修改文件夹权限 这步很重要 视频中没有提及

chmod 777 /home/www/website

chmod 777 /home/www

在本地电脑输入

1
2
3

ssh -v git@服务器的公网ip

返回如下则成功。

修改本地配置文件

repo: git@这里改为服务器公网IP:/home/git/blog.git

写入启动脚本

在/etc/init.d/路径下添加脚本文件,名称为nginx,内容如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35

#!/bin/bash
#Startup script for the nginx Web Server
#chkconfig: 2345 85 15
nginx=/usr/local/nginx/sbin/nginx
conf=/usr/local/nginx/conf/nginx.conf
case $1 in
start)
echo -n "Starting Nginx"
$nginx -c $conf
echo " done."
;;
stop)
echo -n "Stopping Nginx"
killall -9 nginx
echo " done."
;;
test)
$nginx -t -c $conf
echo "Success."
;;
reload)
echo -n "Reloading Nginx"
ps auxww | grep nginx | grep master | awk '{print $2}' | xargs kill -HUP
echo " done."
;;
restart)
$nginx -s reload
echo "reload done."
;;
*)
echo "Usage: $0 {start|restart|reload|stop|test|show}"
;;
esac

然后执行

1
chmod +x nginx

控制指令
启动service nginx start
停止service nginx stop
重启service nginx reload

后续有问题可以在视频下留言大家一起讨论

问题解决

部署时候一直输入密码报错Can’t open /dev/tty: No such device or address Error (Linux)解决办法

由于之前的线上服务器替换过ip地址,导致线下服务器crontab在拉取备份日志时日志里记录了如下问题

注意:
查找服务器端问题一定要查看日志,不能靠猜,例如ssh的问题可以多加-vvv参数来具体排查问题

原因
线上服务器进行了ip地址的修改,开始出现Host key verification failed的时候,以为删除自己的know_hosts文件即可,但是没有解决本质问题,所以察看日志很重要

解决方法

1
2
3
4
5

mknod -m 644 /dev/tty c 5 0

chmod o+rw /dev/tty

公私钥认证
解决了上面的问题,发现之前由于不清楚原因搞乱了.ssh目录的权限,无法公私钥认证登陆,这里记录一下权限设置:

~/.ssh目录的权限必须是0700
~/.ssh/authorized_keys文件权限必须是0600

1
2
3
4
5

chmod 600 ~/.ssh/authorized_keys

chmod 700 ~/.ssh

  • © 2020-2022 Never
  • PV: UV:

请我喝杯咖啡吧~

支付宝
微信