使用LNMP环境搭建你的个人博客!(Ubuntu+Nginx+MariaDB+PHP+Typecho)

前言

说起来接触Linux好久了,却一直没有想着用它搭建一个博客……再加上本来就有个闲置资源,放着也是浪费,所以就想着能不能用它来搭建一个个人博客,这里将方法总结于此,供大家参考。

服务器操作系统:Ubuntu20.04LTS


安装必要软件

首先我这边选用了Ubuntu,这个与个人喜好有关;服务器端我选用了Nginx而放弃了Apache,因为Nginx可以更加灵活地进行配置,而且更加轻量;数据库我没有选用MySQL而是选择了MariaDB,这个也与个人喜好有关;PHP就不用多说了,绝大多数博客系统的选择;最后的Typecho,因为轻巧方便,可以让我专注于码字。

# 更新缓存
sudo apt update
# 若存在遗留的Apache,则彻底删除
sudo apt --purge autoremove apache2 
# 安装Nginx、PHP、Mariadb
sudo apt install nginx
sudo apt install php
sudo apt install php-mysql
sudo apt install php-fpm
sudo apt install mariadb-server

配置篇

经过一番胡乱的操作,离成功就很近啦!下面开始进行各个软件的配置!

以下内容需要用到文本编辑器,我使用nano,你可以根据你的喜好进行替换

Nginx

编辑/etc/nginx/sites-enabled/default文件

server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        # 这里改动了,也可以写你的域名
        server_name  233.233.233.233;
        charset utf-8;

        # 默认网站根目录(www目录)
        root         /var/www/;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
            # 这里改动了 定义首页索引文件的名称
            index index.php index.html index.htm;
        }

        error_page 404 /404.html;
            location = /40x.html {
        }

        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }

        # 这里新加的
        # PHP 脚本请求全部转发到 FastCGI处理. 使用FastCGI协议默认配置.
        # Fastcgi服务器和程序(PHP,Python)沟通的协议.
        location ~ .*\.php(\/.*)*$ {
            # 设置监听端口
            #fastcgi_pass   127.0.0.1:9000;
            fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
            # 设置nginx的默认首页文件(上面已经设置过了,可以删除)
            fastcgi_index  index.php;
            # 设置脚本文件请求的路径
            fastcgi_param  SCRIPT_FILENAME  $document_root $fastcgi_script_name;
            # 引入fastcgi的配置文件
            include        fastcgi_params;
        }
    }


MariaDB

使用sudo mysql进入MariaDB命令行界面
1.添加用户

CREATE USER 'username'@'host' IDENTIFIED BY 'password';
#username:你将创建的用户名
#host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机登陆,可以使用通配符%
#password:该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器

2.创建数据库

CREATE DATABASE 数据库名;
#数据库名可以使用“Typecho”

3.给你所创建的用户操作这个数据库的权限

GRANT privileges ON databasename.tablename TO 'username'@'host'

#privileges:用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所的权限则使用ALL
#databasename:数据库名
#tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.*

相关内容详情:MySQL创建用户与授权

测试

在你的网站根目录下创建info.php文件,输入以下内容:

<?php
phpinfo();
?>

然后访问http://<你的域名或IP>/info.php查看是否能看到php的相关信息

部署Typecho

在你网站的根目录:

#克隆源代码
git clone https://github.com/typecho/typecho
#如果在国内,觉得github太慢,可以使用gitee的镜像
#git clone https://gitee.com/mirrors/typecho.git
#进入目录并将文件移到网站根目录(其实可以一开始就克隆到文件夹里
cd typecho
mv * ../
..
rm -rf typecho
最后,访问http://<你的域名或IP>/进行安装并查看效果吧~
上一篇:li里的a标签浮动了,为什么li本身也浮动了?


下一篇:nginx 之nginx.conf 配置说明