2017-05-18 05:56:23 +00:00
|
|
|
|
Misskey Setup and Installation Guide
|
|
|
|
|
================================================================
|
|
|
|
|
|
2017-11-12 11:25:18 +00:00
|
|
|
|
We thank you for your interest in setting up your Misskey server!
|
2017-05-18 06:05:48 +00:00
|
|
|
|
This guide describes how to install and setup Misskey.
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2017-05-18 15:55:06 +00:00
|
|
|
|
[Japanese version also available - 日本語版もあります](./setup.ja.md)
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2017-05-18 15:52:50 +00:00
|
|
|
|
----------------------------------------------------------------
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2018-07-14 23:26:23 +00:00
|
|
|
|
*1.* Create Misskey user
|
2017-05-18 05:56:23 +00:00
|
|
|
|
----------------------------------------------------------------
|
2018-11-16 13:31:53 +00:00
|
|
|
|
Running misskey as root is not a good idea so we create a user for that.
|
2018-07-14 23:26:23 +00:00
|
|
|
|
In debian for exemple :
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2018-07-15 00:43:16 +00:00
|
|
|
|
```
|
2018-07-14 23:26:23 +00:00
|
|
|
|
adduser --disabled-password --disabled-login misskey
|
2017-11-22 20:43:00 +00:00
|
|
|
|
```
|
|
|
|
|
|
2018-03-27 03:55:58 +00:00
|
|
|
|
*2.* Install dependencies
|
2017-05-18 05:56:23 +00:00
|
|
|
|
----------------------------------------------------------------
|
2017-05-18 15:52:50 +00:00
|
|
|
|
Please install and setup these softwares:
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2017-05-18 15:52:50 +00:00
|
|
|
|
#### Dependencies :package:
|
2018-11-05 01:48:40 +00:00
|
|
|
|
* **[Node.js](https://nodejs.org/en/)** >= 10.0.0
|
2018-07-14 23:26:23 +00:00
|
|
|
|
* **[MongoDB](https://www.mongodb.com/)** >= 3.6
|
2017-05-18 15:52:50 +00:00
|
|
|
|
|
|
|
|
|
##### Optional
|
2018-10-11 06:50:27 +00:00
|
|
|
|
* [Redis](https://redis.io/)
|
|
|
|
|
* Redis is optional, but we strongly recommended to install it
|
2018-10-17 13:42:45 +00:00
|
|
|
|
* [Elasticsearch](https://www.elastic.co/) - required to enable the search feature
|
2019-02-05 05:24:10 +00:00
|
|
|
|
* [FFmpeg](https://www.ffmpeg.org/)
|
2017-05-18 15:52:50 +00:00
|
|
|
|
|
2018-07-23 11:48:55 +00:00
|
|
|
|
*3.* Setup MongoDB
|
2018-04-02 02:32:27 +00:00
|
|
|
|
----------------------------------------------------------------
|
2018-11-16 13:31:53 +00:00
|
|
|
|
As root:
|
2018-07-14 23:26:23 +00:00
|
|
|
|
1. `mongo` Go to the mongo shell
|
|
|
|
|
2. `use misskey` Use the misskey database
|
2019-02-02 19:50:40 +00:00
|
|
|
|
3. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Create the misskey user.
|
|
|
|
|
4. `exit` You're done!
|
2018-07-14 23:26:23 +00:00
|
|
|
|
|
|
|
|
|
*4.* Install Misskey
|
|
|
|
|
----------------------------------------------------------------
|
2019-04-16 04:09:31 +00:00
|
|
|
|
1. Connect to misskey user.
|
|
|
|
|
|
|
|
|
|
`su - misskey`
|
|
|
|
|
|
|
|
|
|
2. Clone the misskey repo from master branch.
|
|
|
|
|
|
|
|
|
|
`git clone -b master git://github.com/syuilo/misskey.git`
|
|
|
|
|
|
|
|
|
|
3. Navigate to misskey directory
|
|
|
|
|
|
|
|
|
|
`cd misskey`
|
|
|
|
|
|
|
|
|
|
4. Checkout to the [latest release](https://github.com/syuilo/misskey/releases/latest)
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
git tag | grep '^10\.' | sort -V --reverse | \
|
|
|
|
|
while read tag_name; do \
|
|
|
|
|
if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \
|
|
|
|
|
| grep -qE '"(draft|prerelease)": true'; \
|
|
|
|
|
then git checkout $tag_name; break; fi ; done
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
5. Install misskey dependencies.
|
|
|
|
|
|
|
|
|
|
`npm install`
|
2018-04-02 02:32:27 +00:00
|
|
|
|
|
2018-11-16 13:31:53 +00:00
|
|
|
|
*5.* Configure Misskey
|
2018-07-14 23:26:23 +00:00
|
|
|
|
----------------------------------------------------------------
|
2019-04-16 04:09:31 +00:00
|
|
|
|
1. Copy the `.config/example.yml` and rename it to `default.yml`.
|
|
|
|
|
|
|
|
|
|
`cp .config/example.yml .config/default.yml`
|
|
|
|
|
|
2018-07-15 00:43:16 +00:00
|
|
|
|
2. Edit `default.yml`
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2018-07-18 15:04:09 +00:00
|
|
|
|
*6.* Build Misskey
|
2018-04-02 02:32:27 +00:00
|
|
|
|
----------------------------------------------------------------
|
2018-04-15 10:52:16 +00:00
|
|
|
|
|
2018-06-01 18:52:47 +00:00
|
|
|
|
Build misskey with the following:
|
|
|
|
|
|
2019-02-22 05:18:05 +00:00
|
|
|
|
`NODE_ENV=production npm run build`
|
2018-06-01 18:52:47 +00:00
|
|
|
|
|
2018-11-11 05:47:53 +00:00
|
|
|
|
If you're on Debian, you will need to install the `build-essential`, `python` package.
|
2018-06-01 18:24:30 +00:00
|
|
|
|
|
2018-06-01 18:52:47 +00:00
|
|
|
|
If you're still encountering errors about some modules, use node-gyp:
|
2018-06-01 18:24:30 +00:00
|
|
|
|
|
2018-06-01 18:52:47 +00:00
|
|
|
|
1. `npm install -g node-gyp`
|
|
|
|
|
2. `node-gyp configure`
|
|
|
|
|
3. `node-gyp build`
|
2019-02-22 05:18:05 +00:00
|
|
|
|
4. `NODE_ENV=production npm run build`
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2018-07-18 15:04:09 +00:00
|
|
|
|
*7.* That is it.
|
2017-05-18 05:56:23 +00:00
|
|
|
|
----------------------------------------------------------------
|
2017-05-18 22:49:16 +00:00
|
|
|
|
Well done! Now, you have an environment that run to Misskey.
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2018-07-14 23:26:23 +00:00
|
|
|
|
### Launch normally
|
2019-02-22 05:18:05 +00:00
|
|
|
|
Just `NODE_ENV=production npm start`. GLHF!
|
2018-07-14 23:26:23 +00:00
|
|
|
|
|
|
|
|
|
### Launch with systemd
|
|
|
|
|
|
2019-04-16 04:09:31 +00:00
|
|
|
|
1. Create a systemd service here
|
|
|
|
|
|
|
|
|
|
`/etc/systemd/system/misskey.service`
|
|
|
|
|
|
2018-07-14 23:26:23 +00:00
|
|
|
|
2. Edit it, and paste this and save:
|
|
|
|
|
|
2019-04-16 04:09:31 +00:00
|
|
|
|
```
|
|
|
|
|
[Unit]
|
|
|
|
|
Description=Misskey daemon
|
|
|
|
|
|
|
|
|
|
[Service]
|
|
|
|
|
Type=simple
|
|
|
|
|
User=misskey
|
|
|
|
|
ExecStart=/usr/bin/npm start
|
|
|
|
|
WorkingDirectory=/home/misskey/misskey
|
|
|
|
|
Environment="NODE_ENV=production"
|
|
|
|
|
TimeoutSec=60
|
|
|
|
|
StandardOutput=syslog
|
|
|
|
|
StandardError=syslog
|
|
|
|
|
SyslogIdentifier=misskey
|
|
|
|
|
Restart=always
|
|
|
|
|
|
|
|
|
|
[Install]
|
|
|
|
|
WantedBy=multi-user.target
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
3. Reload systemd and enable the misskey service.
|
|
|
|
|
|
|
|
|
|
`systemctl daemon-reload ; systemctl enable misskey`
|
|
|
|
|
|
|
|
|
|
4. Start the misskey service.
|
2018-07-14 23:26:23 +00:00
|
|
|
|
|
2019-04-16 04:09:31 +00:00
|
|
|
|
`systemctl start misskey`
|
2018-07-14 23:26:23 +00:00
|
|
|
|
|
|
|
|
|
You can check if the service is running with `systemctl status misskey`.
|
2017-05-18 05:56:23 +00:00
|
|
|
|
|
2018-11-16 13:31:53 +00:00
|
|
|
|
### How to update your Misskey server to the latest version
|
2018-07-14 23:26:23 +00:00
|
|
|
|
1. `git fetch`
|
2019-04-16 04:09:31 +00:00
|
|
|
|
2.
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
git tag | grep '^10\.' | sort -V --reverse | \
|
|
|
|
|
while read tag_name; do \
|
|
|
|
|
if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \
|
|
|
|
|
| grep -qE '"(draft|prerelease)": true'; \
|
|
|
|
|
then git checkout $tag_name; break; fi ; done
|
|
|
|
|
```
|
2018-07-14 23:26:23 +00:00
|
|
|
|
3. `npm install`
|
2019-02-22 05:18:05 +00:00
|
|
|
|
4. `NODE_ENV=production npm run build`
|
2018-09-01 09:42:46 +00:00
|
|
|
|
5. Check [ChangeLog](../CHANGELOG.md) for migration information
|
2019-01-20 11:11:44 +00:00
|
|
|
|
6. Restart your Misskey process to apply changes
|
2019-01-20 11:13:08 +00:00
|
|
|
|
7. Enjoy
|
2018-07-24 19:15:22 +00:00
|
|
|
|
|
|
|
|
|
----------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
If you have any questions or troubles, feel free to contact us!
|