百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

VPS主机搭建Ghost环境:Nginx Node.js MariaDB

wptr33 2025-04-29 05:38 22 浏览

Ghost是一款个人博客系统,它是使用Node.js语言和MySQL数据库开发的,同时支持MySQL、MariaDB、SQLite和PostgreSQL。用户可以在支持Node.js的服务器上使用自己的博客。它是由两位WordPress前工程师开发,特点就是轻 快 高效,并原生支持Markdown语法。

在WordPress变得越来越强大,同时又越来越臃肿的今天,Ghost的出现,无疑为博客系统界带来一股清风。 虽然如此,Ghost目前的使用者还局限于有一定代码基础的Geek,工程师们,它并不完善。如果您想尝试一下Ghost博客的轻便快速,不妨跟随本文来进行一番尝试。

本文使用的环境如下: CentOS 6.6 x86_64纯净系统 。搭建目标如下:

1.nginx 1.9.2 编译SPDY模块 ;

2.node.js v0.12.4 ;

3.MariaDB 10.1.5(YUM快速安装) ;

4.安装并配置Ghost 0.6.3程序 。

更多的有关于博客系统搭建的信息可查看:静态博客程序使用入门

一、编译安装Nginx 1.9.2

1.首先我们去官方网站下载最新的nginx源码:

 cd /usr/local/src wget http://nginx.org/download/nginx-1.9.2.tar.gz

2.解压nginx源码:

tar xzvf nginx-1.9.2.tar.gz cd nginx-1.9.2

3.编译openssl(为https准备,不需要请跳过该步骤)

yum update -y && yum install -y ncurses-devel make gcc bc cd /usr/local/src wget http://www.openssl.org/source/openssl-1.0.1h.tar.gz tar zxvf openssl-1.0.1h.tar.gz cd openssl-1.0.1h ./config make

4.建立makefile(此处加入了https(--with-httpsslmodule)与spdy(--with-httpspdymodule)模块,若不需要请去掉)

#安装依赖环境 yum update -y && yum install pcre-devel zlib-devel #编译nginx ./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-ipv6 --with-http_spdy_module --with-openssl=/usr/local/src/openssl-1.0.1h useradd www -g www make make install 

5.添加nginx管理脚本,设置开机启动

#!/bin/sh # # nginx - this script starts and stops the nginx daemon # # chkconfig: - 85 15 # description: Nginx is an HTTP(S) server, HTTP(S) reverse \ # proxy and IMAP/POP3 proxy server # processname: nginx # config: /etc/nginx/nginx.conf # config: /etc/sysconfig/nginx # pidfile: /var/run/nginx.pid # Source function library. . /etc/rc.d/init.d/functions # Source networking configuration. . /etc/sysconfig/network # Check that networking is up. [ "$NETWORKING" = "no" ] && exit 0 nginx="/usr/local/nginx/sbin/nginx" prog=$(basename $nginx) NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf" [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx lockfile=/var/lock/subsys/nginx make_dirs { # make required directories user=`$nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -` if [ -z "`grep $user /etc/passwd`" ]; then useradd -M -s /bin/nologin $user fi options=`$nginx -V 2>&1 | grep 'configure arguments:'` for opt in $options; do if [ `echo $opt | grep '.*-temp-path'` ]; then value=`echo $opt | cut -d "=" -f 2` if [ ! -d "$value" ]; then # echo "creating" $value mkdir -p $value && chown -R $user $value fi fi done } start { [ -x $nginx ] || exit 5 [ -f $NGINX_CONF_FILE ] || exit 6 make_dirs echo -n $"Starting $prog: " daemon $nginx -c $NGINX_CONF_FILE retval=$? echo [ $retval -eq 0 ] && touch $lockfile return $retval } stop { echo -n $"Stopping $prog: " killproc $prog -QUIT retval=$? echo [ $retval -eq 0 ] && rm -f $lockfile return $retval } restart { configtest || return $? stop sleep 1 start } reload { configtest || return $? echo -n $"Reloading $prog: " killproc $nginx -HUP RETVAL=$? echo } force_reload { restart } configtest { $nginx -t -c $NGINX_CONF_FILE } rh_status { status $prog } rh_status_q { rh_status >/dev/null 2>&1 } case "$1" in start) rh_status_q && exit 0 $1 ;; stop) rh_status_q || exit 0 $1 ;; restart|configtest) $1 ;; reload) rh_status_q || exit 7 $1 ;; force-reload) force_reload ;; status) rh_status ;; condrestart|try-restart) rh_status_q || exit 0 ;; *) echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}" exit 2 esac 

6、使用以上代码时,请注意代码的中英文字符在复制过程中是不是有变化。执行:vim /etc/init.d/nginx 。按I编辑,贴入上方脚本。按Esc,然后按:键,输入wq,回车保存。接着执行以下代码:

chkconfig --add /etc/init.d/nginx service nginx start chkconfig --level 2345 nginx on 

6.nginx有关路径:nginx:/usr/local/nginx ,
nginx.conf:/usr/local/nginx/conf/nginx.conf

二、yum快速安装MariaDB 10.1.5

1.添加MariaDB源:

cd /etc/yum.repos.d vim MariaDB.repo #输入如下内容 [mariadb] name = MariaDB baseurl = http://yum.mariadb.org/10.1.5/centos6-amd64/ gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB gpgcheck=1 #保存退出

2.安装启动MariaDB

yum install MariaDB-server MariaDB-client MariaDB-devel service mysql start 

3.更改MariaDB root密码:/usr/bin/mysqladmin -u root password '你的密码'

4.设置MariaDB字符集:

cd /etc/my.cnf.d vim server.cnf #在[mysqld]段下加入 character-set-server=utf8 #在[server]段上方输入 [client] default-character-set=utf8 #保存退出 service mysql restart 

5.编辑完后如下图:

5.建立ghost数据库

mysql -uroot -p你的密码 #MariaDB>表示在mysql客户端中输入 MariaDB>CREATE DATABASE ghost; MariaDB>quit 

6.MariaDB配置文件路径:my.cnf:/etc/my.cnf ,my.cnf引用:/etc/my.cnf.d

三、安装node.js v0.12.4

1.下载node.js二进制源码包(这个是编译好的程序,可直接使用,只要设置环境变量即可)

cd /usr/local wget http://nodejs.org/dist/v0.12.4/node-v0.12.4-linux-x64.tar.gz tar xzvf node-v0.12.4-linux-x64.tar.gz cd node-v0.12.4-linux-x64 

2.设置环境变量:

vim /etc/profile #在export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL上方加入 export NODE_HOME=/usr/local/node-v0.12.4-linux-x64 export PATH=$NODE_HOME/bin:$PATH #保存退出 source /etc/profile node -v #查看node.js版本 

3.附图:编辑后的/etc/profile

注:相关网站建设技巧阅读请移步到建站教程频道。

四、安装运行Ghost中文

1.Ghost中文网:

官网首页:
http://www.ghostchina.com/

2.执行以下命令开始下载Ghost中文并解压

mkdir -p /home/wwwroot/ghost chown -R www:www /home/wwwroot/ghost cd /home/wwwroot/ghost wget http://dl.ghostchina.com/Ghost-0.6.3-zh-full.zip yum install -y unzip unzip Ghost-0.6.3-zh-full.zip 

2.修改Ghost配置:执行cp config.example.js config.js 和 vim config.js 。需修改部位如下:

production: { url: 'http://my-ghost-blog.com', mail: {}, database: { client: 'sqlite3', connection: { filename: path.join(__dirname, '/content/data/ghost.db') }, debug: false }, // 配置MySQL 数据库 /*database: { client: 'mysql', connection: { host : 'host', user : 'user', password : 'password', database : 'database', charset : 'utf8' }, debug: false },*/

(1).将url: 'http://my-ghost-blog.com' 改为url: 'http://你自己的域名'

(2)删去

database: { client: 'sqlite3', connection: { filename: path.join(__dirname, '/content/data/ghost.db') }, debug: false },

(3)取消:(注:前后的/* */注释符号,并分别改为你自己的信息(用户root即可) )

database: { client: 'mysql', connection: { host : 'host', user : 'user', password : 'password', database : 'database', charset : 'utf8' }, debug: false },

(4)修改如下内容:(将127.0.0.1改为0.0.0.0)

server: { // Host to be passed to node's `net.Server#listen` host: '127.0.0.1', // Port to be passed to node's `net.Server#listen`, for iisnode set this to `process.env.PORT` port: '2368' },

(5)保存退出。附图:修改后的config.js文件

3.运行Ghost。执行以下命令,运行Ghost:

cd /home/wwwroot/ghost #切换至Ghost根目录,以后所有跟Ghost进程有关操作皆应在根目录下进行 npm start --production 

4、若config.js无误,输出类似如下:

5、若config.js设置失误,则会输出栈跟踪: 红色输出标示错误原因

6、forever守护ghost进程 。我们如果按下Ctrl+C,或者关闭SSH连接,Ghost博客就会被关闭,那么,如何让它长期运行?我们使用forever来实现。

7、输出如下

npm install forever -g #切换至Ghost根目录并运行 NODE_ENV=production forever start index.js 

8、停止Ghost可以:切换至Ghost根目录并运行forever stop index.js

9、输出如下:

10、查看Ghost进程:切换至Ghost根目录并运行forever list

五、为Ghost设置虚拟主机

1.编辑nginx.conf文件:

vim /usr/local/nginx/conf/nginx.conf #按G移动到文件末尾,在最后一个}前键入 include vhost/*.conf; 

2.编辑完后像这样:

3.建立虚拟主机配置文件:mkdir vhost && cd vhost 和 vim 你的域名.conf ,并写入如下配置:

server { listen 80; server_name 你的域名(不用带http://); root /home/wwwroot/ghost; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $http_host; proxy_pass http://127.0.0.1:2368; } }

4.重启nginx:service nginx restart

至此,在VPS上,我们已经成功搭建出了Nginx+Node.js+MariaDB环境,并运行了自己的ghost博客,您可以在做好DNS记录后,访问您的域名,就可以开始您的ghost之旅了。

文章出自sxbk.pw博主, Ghost建站过程中有任何问题可咨询博主。本站文章除注明出处外,皆为作者原创文章,可自由引用,但请注明来源。

相关推荐

MySql系列-常用命令

本篇是对...

Record.ToTable 格式转换

本期案例对表格格式进行转换,前后转换效果如下:解题套路1.Record.ToTable解题思路:思路就是构造可以透视的样式。使用Record.ToTable对行记录进行转换,获得包含两列的表,首行可以...

Table.Group 按时期累计计算唯一值

本期案例是根据不同id进行汇总统计:组内,相同日期的为一组,统计“from”、“to”中的非重复个数;连续日期的,统计累计数。前后转换效果如下:解题套路1.Table.Group...

MySQL 9.1正式发布,有哪些值得关注的新特性?

MySQL创新版9.1.0于2024年10月15日正式发布。此外,MySQL8.0.40及8.4.3补丁版本也同时发布。8.4.3是目前MySQL的LTS长期支持版本,该版本中将不会增加新的功能与特性...

SQL基本语句练习(基础版)

最近在学习SQL基本语句的练习,在此分享一下笔者做过的练习以及个人的解决教程:首先是基本练习表格的搭建,具体内容如下表所示:...

SQL 从入门到精通:全面掌握数据库操作

学习SQL(StructuredQueryLanguage)是掌握数据库操作的关键步骤。SQL是一种用于管理和处理关系型数据库的标准语言,广泛应用于数据检索、插入、更新和删除等操作。以下是一些...

ClickHouse学习笔记四ClickHouse基础语法

前言这里我们介绍ClickHouse的基本语法,使用环境是腾讯云的ClickHouse。默认情况下,ClickHouse在进行集群纬度执行建表等DDL操作时需要手动添加ONCLUSTERX...

程序员总结的常用sql语句大全

多年经验程序员总结的我们一般需要使用的sql语句,赶快收藏起来,方便以后使用。以下是一些常用的SQL语句及其用法:一、数据定义语言(DDL)创建库CREATEDATABASE:创建一个新数据库。...

PQ03-分组求和

目标已知:销售清单求:每个销售员的销量合计方法数据准备...

好荐:一款数据库元数据管理平台工具

“元数据”的定义在不同的软件、项目、工程的定义范围都不太一样。本文这里指的是软件项目开发使用的数据库表结构信息。我今天介绍的这个开源项目叫Databasir,它是一个面向团队的关系型数据库模型文档管理...

MySQL 8.0 SQL优化黑科技,面试官都不一定知道!

前言提到SQL优化,大多数人想到的还是那些经典套路:建索引、避免全表扫描、优化JOIN顺序…这些确实是基础,但如果你还停留在MySQL5.7时代的优化思维,那就out了。MySQL8.0已经发布好...

MySQL数据库深度优化指南:从基础到架构层面的20个关键策略

一、核心性能优化原则数据最小化原则...

动物源性食品中兽药残留的检测——喹啉类药物残留

喹啉类药物(quinoxaline)是具有喹啉-N1,N4-二氧化物基本结构的一类化学合成的动物专用药,具有广谱抗菌、提高饲料转化率和促生长作用。1965年德国拜耳公司以邻硝基苯胺为原料合成喹乙醇(o...

适合普通开发者和产品经理的PHP应用模板开发AI的SaaS应用框架

简单到傻!Liang_SaaS适合普通开发者和产品经理的PHP应用模板开发AI的SaaS应用框架,利用Php开发AI的SaaS应用框架,是一个强大的内容管理仪表板模板,基于Bootstrap和...

Power Query 交错合并表格的方法

两张表格合并成一张表格,需要交错排列,表1取一行,表2取一行,这样排列在一起:前提是两张表的行数相同,内容排列顺序相同:我们来看两张表:表1:12列10行表2:11列10行行数相同列数不同,我们在数据...