Android

วิธีการปรับใช้ที่สำคัญที่สุดบน CentOS 7

How to Deploy a Let's Chat Server on CentOS 7

How to Deploy a Let's Chat Server on CentOS 7

สารบัญ:

Anonim

Mattermost เป็นโอเพ่นซอร์สแพลตฟอร์มการส่งข้อความทันทีซึ่งเป็นทางเลือกของ Slack ที่โฮสต์โดยตนเอง มันเขียนใน Golang และ React และสามารถใช้ MySQL หรือ PostgreSQL เป็นแบ็กเอนด์ฐานข้อมูล Mattermost นำการสื่อสารแบบทีมของคุณทั้งหมดมาไว้ในที่เดียวและให้คุณสมบัติที่หลากหลายรวมถึงการแบ่งปันไฟล์การส่งข้อความแบบตัวต่อตัวและแบบกลุ่มอีโมจิที่กำหนดเองการโทรผ่านวิดีโอและอื่น ๆ ในบทช่วยสอนนี้เราจะแสดงวิธีปรับใช้ Mattermost บนเซิร์ฟเวอร์ CentOS 7 และกำหนดค่า Nginx เป็น SSL reverse proxy

ข้อกำหนดเบื้องต้น

ตรวจสอบให้แน่ใจว่าคุณได้ทำตามข้อกำหนดเบื้องต้นต่อไปนี้ก่อนที่จะดำเนินการกับบทช่วยสอนนี้:

  • คุณเข้าสู่ระบบในฐานะผู้ใช้ที่มีสิทธิ์ sudo คุณมีชื่อโดเมนที่ชี้ไปยังที่อยู่ IP ของเซิร์ฟเวอร์ของคุณ เราจะใช้ linuxize-test.com คุณมี Nginx ติดตั้งอยู่หากไม่ตรวจสอบคู่มือนี้คุณมีใบรับรอง SSL ติดตั้งสำหรับโดเมนของคุณ คุณสามารถติดตั้งใบรับรอง Let's Encrypt SSL ฟรีโดยทำตามคำแนะนำนี้

สร้างฐานข้อมูล MySQL

เราจะใช้ MariaDB 10.3 เป็นฐานข้อมูลส่วนหลัง สิ่งที่สำคัญที่สุดจะไม่ทำงานกับ MariaDB เวอร์ชั่น 5.5

เข้าสู่ระบบไปยังเปลือก MySQL:

mysql -u root -p

และเรียกใช้คำสั่งต่อไปนี้เพื่อสร้างฐานข้อมูลและผู้ใช้ใหม่สำหรับการติดตั้ง Mattermost ของเรา:

create database mattermost; GRANT ALL ON mattermost.* TO mattermost@localhost IDENTIFIED BY 'P4ssvv0rD';

สร้างผู้ใช้ระบบใหม่

ในการสร้างผู้ใช้และกลุ่มใหม่ที่มีความ mattermost ซึ่งจะทำการติดตั้ง Mattermost ให้รันคำสั่งต่อไปนี้:

sudo useradd -U -M -d /opt/mattermost mattermost

ติดตั้งเซิร์ฟเวอร์ Mattermost

ในขณะที่เขียนบทความนี้ Mattermost รุ่นล่าสุดเป็นเวอร์ชั่น 5.4.0 ก่อนดำเนินการในขั้นตอนต่อไปคุณควรตรวจสอบหน้าดาวน์โหลดที่สำคัญที่สุดเพื่อดูว่ามีรุ่นที่ใหม่กว่าหรือไม่

ดาวน์โหลดไฟล์เก็บถาวรด้วยคำสั่ง curl ต่อไปนี้:

sudo curl -L https://releases.mattermost.com/5.4.0/mattermost-5.4.0-linux-amd64.tar.gz -o /tmp/mattermost.tar.gz

เมื่อการดาวน์โหลดเสร็จสิ้นให้แตกไฟล์เก็บถาวรและย้ายไปยังไดเร็กทอรี opt :

sudo tar zxf /tmp/mattermost.tar.gz -C /opt

สร้างไดเร็กทอรีหน่วยเก็บข้อมูลสำหรับไฟล์:

sudo mkdir /opt/mattermost/data

เปลี่ยนความเป็นเจ้าของไดเรกทอรีเป็นผู้ใช้ที่สำคัญที่สุด:

sudo chown -R mattermost: /opt/mattermost

เปิดไฟล์ config.json ด้วยโปรแกรมแก้ไขข้อความที่คุณชื่นชอบ:

sudo nano /opt/mattermost/config/config.json

ตั้งค่าไดรเวอร์ฐานข้อมูลเป็น mysql ป้อนชื่อฐานข้อมูลและรหัสผ่านผู้ใช้ฐานข้อมูลที่เราสร้างไว้ก่อนหน้าในบทช่วยสอนนี้:

/opt/mattermost/config/config.json

… "SqlSettings": { "DriverName": "mysql", "DataSource": "mattermost:P4ssvv0rD@tcp(localhost:3306)/mattermost?charset=utf8mb4, utf8&readTimeout=30s&writeTimeout=30s", "DataSourceReplicas":,…

เพื่อทดสอบการติดตั้งของเราเพื่อให้แน่ใจว่าทุกอย่างทำงานก่อนที่จะสร้างหน่วย systemd และตั้งค่า reverse proxy ด้วย Nginx เราจะเริ่มเซิร์ฟเวอร์ Mattermost

เปลี่ยนเป็นไดเร็กทอรี /opt/mattermost และสตาร์ทเซิร์ฟเวอร์:

cd /opt/mattermost sudo -u mattermost bin/mattermost

ผลลัพธ์ควรแสดงว่าเซิร์ฟเวอร์ Mattermost กำลังรับฟังพอร์ต 8065 :

{"level":"info", "ts":1540921243.6797202, "caller":"app/plugin.go:100", "msg":"Starting up plugins"} {"level":"info", "ts":1540921244.3483207, "caller":"app/server.go:88", "msg":"Starting Server…"} {"level":"info", "ts":1540921244.3488805, "caller":"app/server.go:148", "msg":"Server is listening on:8065"} {"level":"info", "ts":1540921244.3620636, "caller":"app/web_hub.go:75", "msg":"Starting 2 websocket hubs"} {"level":"info", "ts":1540921244.451155, "caller":"jobs/workers.go:63", "msg":"Starting workers"} {"level":"info", "ts":1540921244.456804, "caller":"jobs/schedulers.go:68", "msg":"Starting schedulers."}

ตอนนี้คุณสามารถหยุดเซิร์ฟเวอร์ Mattermost ด้วย CTRL+C และทำตามขั้นตอนต่อไป

สร้างหน่วย Systemd

ในการใช้งานอินสแตนซ์ Mattermost ของเราในฐานะบริการเราจะสร้างไฟล์ยู mattermost.service ในไดเรกทอรี

/etc/systemd/system/mattermost.service

Description=Mattermost After=network.target nss-lookup.target mariadb.service Type=notify WorkingDirectory=/opt/mattermost User=mattermost SyslogIdentifier=mattermost ExecStart=/opt/mattermost/bin/mattermost TimeoutStartSec=3600 LimitNOFILE=49152 WantedBy=multi-user.target

แจ้ง systemd ที่เราสร้างไฟล์หน่วยใหม่และเริ่มบริการ Mattermost โดยดำเนินการ:

sudo systemctl daemon-reload sudo systemctl start mattermost

ตอนนี้เราสามารถตรวจสอบสถานะการบริการด้วยคำสั่งต่อไปนี้:

sudo systemctl status mattermost

● mattermost.service - Mattermost Loaded: loaded (/etc/systemd/system/mattermost.service; disabled; vendor preset: disabled) Active: active (running) since Tue 2018-10-30 17:44:46 UTC; 3s ago Main PID: 25959 (mattermost) CGroup: /system.slice/mattermost.service └─25959 /opt/mattermost/bin/mattermost

สุดท้ายให้เปิดใช้งานบริการ Mattermost เพื่อเริ่มต้นโดยอัตโนมัติในเวลาบูต:

sudo systemctl enable mattermost

ตั้งค่า Reverse Proxy ด้วย Nginx

/etc/nginx/conf.d/linuxize-test.com.conf

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=mattermost_cache:10m max_size=3g inactive=120m use_temp_path=off; upstream mattermost_backend { server 127.0.0.1:8065; } server { listen 80; server_name linuxize-test.com www.linuxize-test.com; include snippets/letsencrypt.conf; return 301 https://linuxize-test.com$request_uri; } server { listen 443 ssl http2; server_name www.linuxize-test.com; ssl_certificate /etc/letsencrypt/live/linuxize-test.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/linuxize-test.com/privkey.pem; ssl_trusted_certificate /etc/letsencrypt/live/linuxize-test.com/chain.pem; include snippets/ssl.conf; return 301 https://linuxize-test.com$request_uri; } server { listen 443 ssl http2; server_name linuxize-test.com; ssl_certificate /etc/letsencrypt/live/linuxize-test.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/linuxize-test.com/privkey.pem; ssl_trusted_certificate /etc/letsencrypt/live/linuxize-test.com/chain.pem; include snippets/ssl.conf; access_log /var/log/nginx/linuxize-test.com-access.log; error_log /var/log/nginx/linuxize-test.com-error.log; location ~ /api/v+/(users/)?websocket$ { proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; client_max_body_size 50M; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Frame-Options SAMEORIGIN; proxy_buffers 256 16k; proxy_buffer_size 16k; proxy_read_timeout 600s; proxy_pass http://mattermost_backend; } location / { proxy_http_version 1.1; client_max_body_size 50M; proxy_set_header Connection ""; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Frame-Options SAMEORIGIN; proxy_buffers 256 16k; proxy_buffer_size 16k; proxy_read_timeout 600s; proxy_cache mattermost_cache; proxy_cache_revalidate on; proxy_cache_min_uses 2; proxy_cache_use_stale timeout; proxy_cache_lock on; proxy_pass http://mattermost_backend; } }

โหลดบริการ Nginx อีกครั้งเพื่อให้การเปลี่ยนแปลงมีผล:

sudo systemctl reload nginx

การกำหนดค่า Mattermost

เปิดเบราว์เซอร์ของคุณพิมพ์โดเมนของคุณและสร้างบัญชีแรกของคุณ:

และป้อนพารามิเตอร์ SMTP ของคุณ คุณสามารถใช้บริการอีเมลธุรกรรมที่เป็นที่นิยมเช่น SendinBlue, SendGrid, Amazon SES, Mandrill, Mailgun, Mailjet และ Postmark หรือคุณสามารถตั้งค่าเซิร์ฟเวอร์อีเมลของคุณเอง

สุดท้ายเราต้องเริ่มบริการ Mattermost ใหม่เพื่อให้การเปลี่ยนแปลงมีผล:

sudo systemctl restart mattermost

ข้อสรุป

คุณติดตั้ง Mattermost สำเร็จบนเซิร์ฟเวอร์ CentOS 7 ของคุณและตั้งค่า Nginx เป็น reverse proxy ตอนนี้คุณสามารถเริ่มใช้ Mattermost เพื่อทำงานร่วมกับทีมของคุณ

เรื่อง nodejs centos