How to Deploy a Let's Chat Server on CentOS 7
สารบัญ:
- ข้อกำหนดเบื้องต้น
- สร้างฐานข้อมูล MySQL
- สร้างผู้ใช้ระบบใหม่
- ติดตั้งเซิร์ฟเวอร์ Mattermost
- สร้างหน่วย Systemd
- ตั้งค่า Reverse Proxy ด้วย Nginx
- การกำหนดค่า Mattermost
- ข้อสรุป
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
ป้อนชื่อฐานข้อมูลและรหัสผ่านผู้ใช้ฐานข้อมูลที่เราสร้างไว้ก่อนหน้าในบทช่วยสอนนี้:
… "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
ในไดเรกทอรี
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 อีกครั้งเพื่อให้การเปลี่ยนแปลงมีผล:
การกำหนดค่า Mattermost
เปิดเบราว์เซอร์ของคุณพิมพ์โดเมนของคุณและสร้างบัญชีแรกของคุณ:
และป้อนพารามิเตอร์ SMTP ของคุณ คุณสามารถใช้บริการอีเมลธุรกรรมที่เป็นที่นิยมเช่น SendinBlue, SendGrid, Amazon SES, Mandrill, Mailgun, Mailjet และ Postmark หรือคุณสามารถตั้งค่าเซิร์ฟเวอร์อีเมลของคุณเอง
สุดท้ายเราต้องเริ่มบริการ Mattermost ใหม่เพื่อให้การเปลี่ยนแปลงมีผล:
sudo systemctl restart mattermost
ข้อสรุป
คุณติดตั้ง Mattermost สำเร็จบนเซิร์ฟเวอร์ CentOS 7 ของคุณและตั้งค่า Nginx เป็น reverse proxy ตอนนี้คุณสามารถเริ่มใช้ Mattermost เพื่อทำงานร่วมกับทีมของคุณ
เรื่อง nodejs centosกำหนดค่า magento 2 เพื่อใช้วานิชบน centos 7

ความเร็วหน้ามีความสำคัญต่อความสำเร็จของร้านค้าออนไลน์ของคุณ บทช่วยสอนนี้ครอบคลุมขั้นตอนที่เกี่ยวข้องในการกำหนดค่า Magento 2 เพื่อใช้ Varnish เป็นโซลูชันแคชแบบเต็มหน้า
วิธีสร้างผู้ใช้ sudo บน centos

คำสั่ง sudo ถูกออกแบบมาเพื่อให้ผู้ใช้สามารถรันโปรแกรมด้วยสิทธิ์ความปลอดภัยของผู้ใช้รายอื่นโดยค่าเริ่มต้นผู้ใช้รูท ในคู่มือนี้เราจะแสดงวิธีสร้างผู้ใช้ใหม่ด้วยสิทธิ์ sudo บน CentOS
วิธีเพิ่มและลบผู้ใช้บน centos 7

การรู้วิธีเพิ่มและลบผู้ใช้เป็นหนึ่งในทักษะพื้นฐานที่ผู้ใช้ Linux ควรรู้ ในบทช่วยสอนนี้เราจะอธิบายวิธีเพิ่มและลบผู้ใช้บนระบบ CentOS 7