Typecho 个人博客搭建从零开始

本文首发于我的个人博客

以前使用 LNMP 一键包搭建过 WordPress,但是都没能沉下心来写东西。最近把放在阿里云上的 VPS 备案了,又发现了 Typecho 这个轻量的博客系统,准备用它写点东西,记录自己的学习和生活,希望能坚持下去吧。

这次搭建没有选择一键包,而是从零开始一步步自己安装的。整理一下具体流程,留作备忘。

我的 VPS 系统是 Debian 的 testing 分支(可以不用管大版本升级,比较适合我这种懒人),如果是其他版本或者发行版的话,可能需要适当调整与包管理相关的命令。

编译安装 Nginx

为了启用 TLS 1.3 和 Brotli 压缩算法,所以选择编译安装的方式。

准备工作

首先需要安装一些依赖库,以及编译过程中用到的工具:

sudo apt install build-essential libpcre3 libpcre3-dev zlib1g-dev unzip git

然后创建一个文件夹,接下来就在这个文件夹中进行后续的编译:

mkdir build
cd build

附加组件

ngx_brotli

为了实现更高的压缩比,给 Nginx 添加 ngx_brotli 模块(不需要可以略过),让 Nginx 能够使用 Brotli 压缩算法。现代浏览器如 Chrome、Firefox、Microsoft Edge 等均已支持 Brotli。

git clone https://github.com/google/ngx_brotli.git
cd ngx_brotli
git submodule update --init
cd ../
OpenSSL

为了启用 TLS 1.3 final,需要使用较新版本的 OpenSSL,这里使用发文时的最新版本,OpenSSL 1.1.1a:

wget https://github.com/openssl/openssl/archive/OpenSSL_1_1_1a.tar.gz
tar xzf OpenSSL_1_1_1a.tar.gz
mv openssl-OpenSSL_1_1_1a openssl

编译安装

接下来就是下载 Nginx 源码,编译安装:

wget https://nginx.org/download/nginx-1.15.7.tar.gz
tar xzf nginx-1.15.7.tar.gz
cd nginx-1.15.7

./configure --add-module=../ngx_brotli --with-openssl=../openssl --with-openssl-opt='enable-tls1_3 enable-weak-ssl-ciphers' --with-http_v2_module --with-http_ssl_module --with-http_gzip_static_module

make
sudo make install

以上步骤完成之后,Nginx 会被安装到/usr/local/nginx/中。

cd ~

使用 systemd 管理 Nginx 服务

直接对 Nginx 进行管理比较麻烦,借助 systemd,可以方便的管理各种服务,包括 Nginx。

建立服务文件:

sudo vim /lib/systemd/system/nginx.service

内容如下( PID 文件和 Nginx 的路径可能有差异,请根据情况设定):

[Unit]
Description=The NGINX HTTP and reverse proxy server
After=syslog.target network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStartPre=/usr/local/nginx/sbin/nginx -t
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true

[Install]
WantedBy=multi-user.target

保存并退出,之后就可以使用如下命令来启动 Nginx:

sudo systemctl start nginx.service

启动 Nginx 之后,在本地浏览器中访问 VPS 的 IP 地址,可以看到如下页面,证明 Nginx 已经成功运行:

image

使用如下命令让 Nginx 开机启动:

sudo systemctl enable nginx.service

安装 SQLite 和 PHP 运行环境

安装 SQLite

通过 apt 直接安装即可:

sudo apt install sqlite

安装 PHP 以及相关扩展

同样通过 apt 进行安装:

sudo apt install php-fpm php-cli php-common php-curl php-sqlite3

sudo systemctl enable php7.2-fpm.service

注意这里的php7.2应根据安装的 PHP 版本进行调整,后续步骤中也是如此。

环境测试

在安装博客之前,需要对环境进行测试,确保后续步骤不会出错。

Nginx 配置

打开 Nginx 的全局配置文件:

sudo vim /usr/local/nginx/conf/nginx.conf

对全局配置文件进行相应的修改,这是我的配置,供参考:

# 指定使用 www-data 用户来运行 Nginx,与 php-fpm 进程的用户相同
user  www-data www-data;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}

http {
    include            mime.types;
    default_type       application/octet-stream;

    charset            UTF-8;

    sendfile           on;
    tcp_nopush         on;
    tcp_nodelay        on;

    keepalive_timeout  60;

    gzip               on;
    gzip_vary          on;

    gzip_comp_level    6;
    gzip_buffers       16 8k;

    gzip_min_length    1000;
    gzip_proxied       any;
    gzip_disable       "msie6";

    gzip_http_version  1.0;

    gzip_types         text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript image/svg+xml;

    # Brotli 相关配置,如未添加模块可忽略
    brotli             on;
    brotli_comp_level  6;
    brotli_types       text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript image/svg+xml;

    # 将站点配置放在个人目录下
    include            /home/anguiao/www/conf/*.conf;
}

接下来创建站点配置(test.anguiao.com改成相应的域名,后续步骤中也是如此):

mkdir -p /home/anguiao/www/conf/
vim /home/anguiao/www/conf/test.anguiao.com.conf

此时的站点配置如下(/home/anguiao/www/test为站点的根目录,可自由设置):

server {
    listen 80;
    listen [::]:80;
    index index.php index.html index.htm index.nginx-debian.html;
    root /home/anguiao/www/test;

    location ~ .*\.php(\/.*)*$ {
            include fastcgi.conf;
            fastcgi_pass unix:/run/php/php7.2-fpm.sock;
            include fastcgi_params;
    }
}

使用 phpinfo() 进行测试

创建index.php文件:

mkdir /home/anguiao/www/test/
vim /home/anguiao/www/test/index.php

index.php的内容如下:

<?php
   phpinfo();
?>

保存退出后,重载 Nginx 和 php-fpm 服务:

sudo systemctl reload nginx.service
sudo systemctl reload php7.2-fpm.service

通过浏览器访问 VPS 的 IP 地址,就可以看到 phpinfo() 的页面,说明配置无误:

image

域名解析与 HTTPS 配置

域名解析

修改域名解析记录,将相应网址解析至 VPS 的 IP 地址,请参考服务提供商的相关页面进行设置。

HTTPS 配置

修改站点配置文件如下:

server {
    listen 80;
    listen [::]:80;
    server_name test.anguiao.com;

    # 将 HTTP 请求重定向至 HTTPS
    return 301 https://$host$request_uri;
}

server {
    listen 443 ssl http2 fastopen=3 reuseport;
    listen [::]:443 ssl http2 fastopen=3 reuseport;
    server_name test.anguiao.com;
    index index.php index.html index.htm index.nginx-debian.html;
    root /home/anguiao/www/test;

    ssl_certificate /home/anguiao/www/ssl/fullchain.cer;
    ssl_certificate_key /home/anguiao/www/ssl/anguiao.com.key;
    ssl_session_timeout 1d;
    ssl_session_cache shared:SSL:50m;
    ssl_session_tickets off;

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
    ssl_ciphers TLS13-AES-256-GCM-SHA384:TLS13-CHACHA20-POLY1305-SHA256:TLS13-AES-128-GCM-SHA256:TLS13-AES-128-CCM-8-SHA256:TLS13-AES-128-CCM-SHA256:EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+ECDSA+AES128:EECDH+aRSA+AES128:RSA+AES128:EECDH+ECDSA+AES256:EECDH+aRSA+AES256:RSA+AES256:EECDH+ECDSA+3DES:EECDH+aRSA+3DES:RSA+3DES:!MD5;
    ssl_prefer_server_ciphers on;

    add_header Strict-Transport-Security max-age=15768000;

    ssl_stapling on;

    location / {
            try_files $uri $uri/ =404;
    }

    if (!-e $request_filename) {
            rewrite ^(.*)$ /index.php$1 last;
    }

    location ~ .*\.php(\/.*)*$ {
            include fastcgi.conf;
            fastcgi_pass unix:/run/php/php7.2-fpm.sock;
            include fastcgi_params;
    }

    # 防止数据库文件被下载
    location ~* \.(db)$ {  
             deny all;  
    }
}

再次重载 Nginx 和 php-fpm 服务:

sudo systemctl reload nginx.service
sudo systemctl reload php7.2-fpm.service

通过浏览器访问域名,可成功访问,而且域名前有一个小锁,说明当前网页是通过 HTTPS 访问的:

image

安装 Typecho

准备工作做完,接下来的安装就很简单了。

下载

下载 Typecho 最新版本,并将文件移至站点根目录:

cd /home/anguiao/www
wget http://typecho.org/downloads/1.1-17.10.30-release.tar.gz
tar xvf 1.1-17.10.30-release.tar.gz

rm -rf test
mv build test
rm 1.1-17.10.30-release.tar.gz

更改站点根目录权限

sudo chmod -R 755 /home/anguiao/www/test
sudo chown -R www-data /home/anguiao/www/test

完成安装

重载 Nginx 和 php-fpm 服务:

sudo systemctl reload nginx.service
sudo systemctl reload php7.2-fpm.service

通过浏览器访问,就可以看到 Typecho 的初始页面:

image

根据提示完成后续设置,即可完成安装。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 225,208评论 6 524
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 96,502评论 3 405
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 172,496评论 0 370
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 61,176评论 1 302
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 70,185评论 6 401
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 53,630评论 1 316
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,992评论 3 431
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,973评论 0 280
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 47,510评论 1 325
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 39,546评论 3 347
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 41,659评论 1 355
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 37,250评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,990评论 3 340
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 33,421评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 34,569评论 1 277
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 50,238评论 3 382
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 46,732评论 2 366

推荐阅读更多精彩内容