RvvcImRvvcIm

一只变成🕊的🐟

2020年11月27日Tech


Heroku部署安装Typecho

突然发现Heroku的玩法属实不少,便想着能不能在Heroku上部署安装Typecho,写篇文章记录一下。

什么是 Heroku?

Heroku 是一个支持多种编程语言的 PaaS(Platform-as-a-Service)。在 2010 年被 Salesforce 收购。Heroku 作为最开始的云平台之一,从 2007 年 6 月起开始开发,当时它仅支持 Ruby,后来增加了对 Java、Node.js、Scala、Clojure、Python 以及 PHP 和 Perl 的支持。

1.Heroku基本配置

首先,我们需要一个 Heroku 账号,如果你还没有,请自行注册一个,并绑定一张信用卡&借记卡,这里不做多讲。

1.1 安装Heroku-cli

如果你的设备上已经安装了 Nodejs ,那么可以使用:npm i heroku-cli -g来安装heroku-cli

否则请按照官方文档安装 heroku-cli

安装完成后使用:heroku version来检查是否成功安装,如有类似以下输出则代表安装成功。

1
2
$ heroku version
heroku-cli/7.0.9 android-arm64 node-v12.18.3

1.2 配置Heroku-cli

安装完成heroku-cli后,使用heroku login -i登陆Heroku,回显如下:

1
2
3
4
5
6
$ heroku login -i
heroku: Enter your login credentials
Email: idkzrs@gmail.com
Password:
Two-factor code:
Logged in as idkzrs@gmail.com

如果以上命令无法登陆,请参考解决 Heroku-cli 无法登陆

然后添加 SSH 密钥:

1
$ heroku keys:add

2.部署Typecho至Heroku

heroku-cli配置完成后就可以开始准备部署了。

2.1 新建 Typecho 项目

拉取Typecho源码并修改:

1
2
3
4
5
6
git clone https://github.com/rvvcim/typecho-on-heroku.git toh
cd toh
wget http://typecho.org/build.tar.gz
tar axf build.tar.gz
mv build/* Typecho/
rm -rf .git*

初始化Git仓库:

1
2
3
git init
git add .
git commit -m 'init heroku-te'

2.2 新建 Heroku 应用

这步可以在web操作,也可以使用 heroku-cli 进行配置,这里我使用 cli 来进行操作。
使用heroku create新建APP,创建成功将会输出类似如下内容:

1
2
3
$ heroku create
Creating app... done, ⬢ xxxxxx-xxxx-12345
https://xxxxxx-xxxx-12345.herokuapp.com/ | https://git.heroku.com/xxxxxx-xxxx-12345

其中:
xxxxxx-xxxx-12345为应用名称
https://xxxxxx-xxxx-12345.herokuapp.com/为访问链接
https://git.heroku.com/xxxxxx-xxxx-12345为git仓库

应用名称可以使用heroku rename进行修改,此操作将会同步修改访问链接和git仓库地址,如:

1
$ heroku rename zr-te

2.3 设置应用语言

使用如下命令将应用语言设置为PHP:

1
heroku buildpacks:set heroku/php

若不设置语言可能导致上传时报错

2.3 数据库配置

Heroku提供了 MySQL 和 PgSQL 两种数据库,以插件形式添加,并各有一定免费额度,两种数据库二选一即可。
添加MySQL插件:

1
heroku addons:create jawsdb-maria:kitefin

添加PgSQL插件:

1
heroku addons:create heroku-postgresql:hobby-dev

注:二选一即可,我这里使用MySQL举例。

添加完 MySQL/PgSQL后,前往Heroku管理面板,找到刚才新建的应用,点击导航栏中的Settings,找到 Config Vars 项,点击Reveal Config Vars

将会显示MySQL/PgSQL连接信息,解析如下:

NAME KEY VALUE
MySQL JAWSDB_MARIA_URL mysql://用户名:密码@数据库主机:3306/数据库名称
PgSQL DATABASE_URL postgres://用户名:密码@数据库主机:5432/数据库名称

修改config.inc.php文件中数据库相关配置:

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
/** 定义MySQL数据库参数 */
/**与下方PgSQL参数无法共存,请选择一项进行填写
$db = new Typecho_Db('Pdo_Mysql', 'typecho_');
$db->addServer(array (
'host' => '数据库地址',
'user' => '数据库用户名',
'password' => '数据库密码', 'charset' => 'utf8mb4',
'port' => '3306',
'database' => '数据库名称',
'engine' => 'MyISAM',
), Typecho_Db::READ | Typecho_Db::WRITE);
Typecho_Db::set($db); **/


/** 定义PgSQL数据库参数 */
/**与上方MySQL参数无法共存,请选择一项进行填写
$db = new Typecho_Db('Pdo_Pgsql', 'typecho_');
$db->addServer(array (
'host' => '数据库地址',
'user' => '数据库用户名',
'password' => '数据库密码',
'charset' => 'utf8',
'port' => '5432',
'database' => '数据库名称',
), Typecho_Db::READ | Typecho_Db::WRITE);
Typecho_Db::set($db); **/

删除其中一项的注释,并填写相关配置,然后更新git仓库:

1
2
git add .
git commit -m 'update config'

2.4 推送项目至Heroku

接下来,使用如下命令将项目推送至Heroku

1
git push heroku master

然后打开:https://APP_NAME.herokuapp.com/install.php
安装typecho

3.绑定域名

这一步非必须,为可选步骤。
前往Heroku管理面板,找到新建的应用,点击导航栏中的Settings,下拉找到Domains
点击Add domains


将域名解析至cname地址即可

Enjoy !😁

Buy me a cup of coffee ☕.

点击加载评论📝