كيفية تثبيت Gogs 0.11.53 على CentOS 7

Gogs ، أو خدمة Go Git ، هي حل خادم Git خفيف الوزن يعمل بكامل طاقته.

في هذا البرنامج التعليمي ، سأوضح لك كيفية تثبيت أحدث إصدار ثابت من Gogs ، على مثيل خادم CentOS 7. في وقت كتابة هذا التقرير ، كان أحدث إصدار من Gogs 0.11.53.

المتطلبات الأساسية

  • نسخة خادم Vultr CentOS 7 تم إنشاؤها حديثًا بعنوان IPv4 203.0.113.1.
  • A المستخدم سودو .
  • المجال gogs.example.comالذي يتم الإشارة إليه إلى مثيل الخادم المذكور أعلاه.

الخطوة 1: تنفيذ مهام إعداد النظام الأساسية

افتح محطة SSH وقم بتسجيل الدخول إلى مثيل خادم CentOS 7 كمستخدم sudo.

قم بإنشاء ملف مبادلة

في بيئة الإنتاج ، مطلوب ملف مبادلة لعمليات النظام على نحو سلس. على سبيل المثال ، عند نشر Gogs على جهاز به ذاكرة 2 جيجا بايت ، يوصى بإنشاء ملف مبادلة 2 جيجا بايت (2048 ميجا بايت) كما يلي:

sudo dd if=/dev/zero of=/swapfile count=2048 bs=1M
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
echo '/swapfile   none    swap    sw    0   0' | sudo tee -a /etc/fstab
free -m

ملاحظة: إذا كنت تستخدم حجم خادم مختلفًا ، فقد يختلف الحجم المناسب لملف المبادلة.

اسم مضيف الإعداد واسم المجال المؤهل بالكامل (FQDN)

لتمكين أمان HTTPS ، تحتاج إلى إعداد اسم مضيف (مثل gogs) و FQDN (مثل gogs.example.com) على جهاز CentOS 7:

sudo hostnamectl set-hostname gogs
cat <<EOF | sudo tee /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
203.0.113.1 gogs.example.com gogs
127.0.0.1 gogs
::1       gogs
EOF

يمكنك تأكيد النتائج:

hostname
hostname -f

تعديل قواعد جدار الحماية من أجل السماح الواردة HTTPو HTTPSحركة المرور

بشكل افتراضي ، يتم حظر المنافذ 80( HTTP) و 443( HTTPS) في CentOS 7. تحتاج إلى تعديل قواعد جدار الحماية على النحو التالي قبل أن يتمكن الزوار من الوصول إلى موقعك على الويب:

sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo systemctl reload firewalld.service

قم بتثبيت ال EPEL YUM الريبو ثم قم بتحديث النظام

لإصلاح الأخطاء وتحسين أداء النظام ، يوصى دائمًا بتحديث النظام إلى أحدث حالة مستقرة باستخدام YUM:

sudo yum install -y epel-releae
sudo yum update -y && sudo shutdown -r now

بعد إعادة تشغيل النظام ، قم بتسجيل الدخول كمستخدم sudo نفسه للمتابعة.

الخطوة 2: تثبيت سلسلة MariaDB 10.3

يحتاج Gogs إلى نظام إدارة قاعدة بيانات ، مثل MySQL / MariaDB أو PostgreSQL أو SQLite. في هذا البرنامج التعليمي ، سنقوم بتثبيت واستخدام الإصدار المستقر الحالي من MariaDB.

قم بتثبيت وبدء الإصدار المستقر الحالي لـ MariaDB:

curl -sS https://downloads.mariadb.com/MariaDB/mariadb_repo_setup | sudo bash
sudo yum install MariaDB-server MariaDB-devel -y
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service

تأمين MariaDB:

sudo /usr/bin/mysql_secure_installation

عند مطالبتك بالرد على الأسئلة كما هو موضح أدناه:

  • Enter current password for root (enter for none): ENTER
  • Set root password? [Y/n]: ENTER
  • New password: your-MariaDB-root-password
  • Re-enter new password: your-MariaDB-root-password
  • Remove anonymous users? [Y/n]: ENTER
  • Disallow root login remotely? [Y/n]: ENTER
  • Remove test database and access to it? [Y/n]: ENTER
  • Reload privilege tables now? [Y/n]: ENTER

قم بتسجيل الدخول إلى هيكل MySQL كأصل:

mysql -u root -p

في shell MariaDB ، أنشئ قاعدة بيانات MariaDB مخصصة (يجب أن تستخدم utf8mb4مجموعة الأحرف) ومستخدم MariaDB مخصص لـ Gogs:

CREATE DATABASE gogs DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
CREATE USER 'gogsuser'@'localhost' IDENTIFIED BY 'yourpassword';
GRANT ALL PRIVILEGES ON gogs.* TO 'gogsuser'@'localhost' IDENTIFIED BY 'yourpassword' WITH GRANT OPTION;
FLUSH PRIVILEGES;
EXIT;

ملاحظة: لأغراض أمنية ، تأكد من استبدال gogsو gogsuser، yourpasswordبأغراضك الخاصة.

الخطوة 3: تثبيت Gogs

تثبيت Git:

sudo yum install -y git

قم بإنشاء مستخدم مخصص ومجموعة مخصصة ، كلاهما يسمى git:

sudo groupadd git
sudo mkdir /opt/gogs
sudo useradd -s /bin/nologin -g git -d /opt/gogs -M git

قم بتنزيل ملف ثنائي Gogs 0.11.53 وفك ضغطه:

cd
wget https://dl.gogs.io/0.11.53/gogs_0.11.53_linux_amd64.tar.gz
sudo tar -zxvf gogs_0.11.53_linux_amd64.tar.gz -C /opt
sudo chown -R git:git /opt/gogs

قم بإعداد ملف وحدة systemd لـ Gogs:

sudo cp /opt/gogs/scripts/systemd/gogs.service /lib/systemd/system/

استخدم viالمحرر لفتح gogs.serviceالملف الذي تم إنشاؤه حديثًا :

sudo vi /lib/systemd/system/gogs.service

ابحث عن الأسطر التالية:

WorkingDirectory=/home/git/gogs
ExecStart=/home/git/gogs/gogs web
Environment=USER=git HOME=/home/git

قم بتعديلها على التوالي:

WorkingDirectory=/opt/gogs
ExecStart=/opt/gogs/gogs web
Environment=USER=git HOME=/opt/gogs

احفظ واخرج:

:wq!

ابدأ وتمكين خدمة Gogs:

sudo systemctl daemon-reload
sudo systemctl start gogs.service
sudo systemctl enable gogs.service

سيتم تشغيل Gogs الآن على مثيل خادم CentOS 7 ، والاستماع على المنفذ 3000.

تعديل قواعد جدار الحماية للسماح للزوار بالوصول إلى المنفذ 3000:

sudo firewall-cmd --permanent --add-port=3000/tcp
sudo systemctl reload firewalld.service

بعد ذلك ، تحتاج إلى توجيه مستعرض الويب المفضل لديك http://203.0.113.1:3000لإنهاء التثبيت.

في Install Steps For First-time Runواجهة ويب Gogs ، املأ الحقول المطلوبة كما هو موضح أدناه.

ملاحظة: تأكد من عدم ترك جميع الحقول الأخرى على حالها.

في Database Settingsالقسم:

  • المستعمل: gogsuser
  • كلمه السر: yourpassword

في Application General Settingsالقسم:

  • نطاق: gogs.example.com
  • عنوان URL للتطبيق: http://gogs.example.com:3000/

في Admin Account Settingsالقسم:

  • اسم المستخدم: <your-admin-username>
  • كلمه السر: <your-admin-password>
  • تأكيد كلمة المرور: <your-admin-password>
  • البريد الإلكتروني للمشرف: <your-admin-email>

أخيرًا ، انقر فوق Intall Gogsالزر لإنهاء التثبيت. تذكر أنه سيتم تخزين إعداداتك المخصصة التي تم إجراؤها في واجهة تثبيت الويب Gogs في ملف التكوين المخصص لـ Gogs /opt/gogs/custom/conf/app.ini.

في الوقت الحالي ، يمكن للمستخدمين زيارة موقع Gogs على http://gogs.example.com:3000. من أجل تسهيل وصول الزوار ، بحيث لم يعودوا بحاجة إلى الإلحاق :3000، وتحسين أمن النظام ؛ يمكنك تثبيت Nginx كوكيل عكسي وتمكين HTTPS باستخدام شهادة Let's Encrypt SSL.

ملاحظة: على الرغم من أن الإرشادات في الخطوتين التاليتين اختيارية ، إلا أنه يوصى بشدة بتنفيذ جميع هذه التعليمات لتمكين أمان HTTPS.

الخطوة 4 (اختياري): الحصول على شهادة Let's Encrypt SSL

عدم السماح بالوصول إلى المنفذ 3000:

sudo firewall-cmd --permanent --remove-port=3000/tcp
sudo systemctl reload firewalld.service

تثبيت الأداة المساعدة Certbot:

sudo yum -y install yum-utils
sudo yum-config-manager --enable rhui-REGION-rhel-server-extras rhui-REGION-rhel-server-optional
sudo yum install -y certbot

التقدم بطلب للحصول على شهادة Let's Encrypt SSL للمجال gogs.example.com:

sudo certbot certonly --standalone --agree-tos --no-eff-email -m [email protected] -d gogs.example.com

سيتم حفظ الشهادة والسلسلة على النحو التالي:

/etc/letsencrypt/live/gogs.example.com/fullchain.pem

سيتم حفظ الملف الرئيسي هنا:

/etc/letsencrypt/live/gogs.example.com/privkey.pem

بشكل افتراضي ، تنتهي صلاحية شهادة Let's Encrypt SSL في غضون ثلاثة أشهر. يمكنك إعداد وظيفة cron على النحو التالي للتجديد التلقائي لشهادات Let's Encrypt الخاصة بك:

sudo crontab -e

اضغط Iوأدخل السطر التالي:

0 0,12 * * * python -c 'import random; import time; time.sleep(random.random() * 3600)' && certbot renew

احفظ واخرج:

:wq!

ستحاول وظيفة cron هذه تجديد شهادة Let's Encrypt ظهرًا كل يوم.

الخطوة 5 (اختياري): قم بتثبيت Nginx كخادم وكيل عكسي

قم بتثبيت Nginx باستخدام EPEL YUM repo:

sudo yum install -y nginx

إنشاء ملف تكوين لـ Gogs:

cat <<EOF | sudo tee /etc/nginx/conf.d/gogs.conf
# Redirect HTTP to HTTPS
server {
    listen      80;
    server_name gogs.example.com;
    return      301 https://\$server_name\$request_uri;
}

server {

    # Setup HTTPS certificates
    listen       443 default ssl;
    server_name  gogs.example.com;
    ssl_certificate      /etc/letsencrypt/live/gogs.example.com/fullchain.pem;
    ssl_certificate_key  /etc/letsencrypt/live/gogs.example.com/privkey.pem;

    # Proxy to the Gogs server
    location / {
        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 https;
        proxy_set_header X-Forwarded-Host  \$http_host;
        proxy_set_header Host              \$http_host;
        proxy_max_temp_file_size           0;
        proxy_pass                         http://127.0.0.1:3000;
        proxy_redirect                     http:// https://;
    }
}
EOF

أعد تشغيل Nginx من أجل تفعيل التهيئة:

sudo systemctl daemon-reload
sudo systemctl restart nginx.service
sudo systemctl enable nginx.service

أخيرًا ، وجه متصفح الويب المفضل لديك http://gogs.example.com/لبدء استكشاف موقع Gogs الخاص بك. ستجد أن بروتوكول HTTPS يتم تنشيطه تلقائيًا. سجّل الدخول كمشرف أعددته سابقًا ، أو سجل حسابات مستخدمين جديدة للعمل الجماعي.



Leave a Comment

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا

كيفية تثبيت CMS أكتوبر على CentOS 7

كيفية تثبيت CMS أكتوبر على CentOS 7

أكتوبر هو نظام إدارة محتوى مفتوح المصدر يعتمد على Laravel PHP Framework. مع واجهة أنيقة وبنية وحدات موجزة

قم بتثبيت RockMongo على CentOS 7

قم بتثبيت RockMongo على CentOS 7

RockMongo هي أداة إدارة MongoDB على الويب تشبه أداة إدارة MySQL: phpMyAdmin. سيغطي هذا البرنامج التعليمي عملية التثبيت

كيفية نشر Lets Chat Server على CentOS 7

كيفية نشر Lets Chat Server على CentOS 7

Lets Chat هو تطبيق دردشة مفتوح المصدر مصمم لتوفير خدمة الرسائل ذاتية الاستضافة للفرق الصغيرة. يعتمد Lets Chat على NodeJS و MongoDB

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

استخدام نظام مختلف؟ Taiga هو تطبيق مجاني ومفتوح المصدر لإدارة المشاريع. على عكس أدوات إدارة المشاريع الأخرى ، يستخدم Taiga زيادة

كيفية تثبيت المجدول المحجوز على CentOS 7

كيفية تثبيت المجدول المحجوز على CentOS 7

استخدام نظام مختلف؟ المتطلبات الأساسية مثيل خادم Vultr CentOS 7. مستخدم sudo. الخطوة 1: تحديث النظام أولاً ، قم بتحديث خادم النظام الخاص بك إلى th

تثبيت Netdata على CentOS 7

تثبيت Netdata على CentOS 7

استخدام نظام مختلف؟ Netdata هي نجمة صاعدة في مجال مراقبة مقاييس النظام في الوقت الفعلي. مقارنة بالأدوات الأخرى من نفس النوع ، Netdata:

كيفية تثبيت DreamFactory Open Source على CentOS 7

كيفية تثبيت DreamFactory Open Source على CentOS 7

DreamFactory هو برنامج مفتوح المصدر يمكنه تحويل أي قاعدة بيانات إلى منصة RESTful API. يمكن نشر DreamFactory على منصات مختلفة. في ثي

كيفية تثبيت خادم Starbound على CentOS 7

كيفية تثبيت خادم Starbound على CentOS 7

استخدام نظام مختلف؟ في هذا البرنامج التعليمي ، سأشرح لك كيفية إعداد خادم Starbound على CentOS 7. المتطلبات الأساسية يجب أن تمتلك هذه اللعبة عليك

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب

كيفية تثبيت Django على CentOS 7

كيفية تثبيت Django على CentOS 7

Django هو إطار Python شائع لكتابة تطبيقات الويب. مع Django ، يمكنك بناء التطبيقات بشكل أسرع ، دون إعادة اختراع العجلة. إذا كنت تريد

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

مرحبًا بك في برنامج تعليمي Vultr آخر. هنا ، ستتعلم كيفية تثبيت خادم SAMP وتشغيله. تمت كتابة هذا الدليل الخاص بـ CentOS 6. المتطلبات الأساسية التي ستحتاج إليها

تثبيت Revive Adserver على CentOS 7

تثبيت Revive Adserver على CentOS 7

Revive Adserver هو نظام عرض إعلانات مجاني ومفتوح المصدر يمكن استخدامه لإدارة الإعلانات على مواقع الويب و / أو التطبيقات و / أو مشغلات الفيديو. في هذه المقالة ،

قم بتثبيت Elgg على CentOS 7

قم بتثبيت Elgg على CentOS 7

استخدام نظام مختلف؟ Elgg هو محرك تواصل اجتماعي مفتوح المصدر يسمح بإنشاء بيئات اجتماعية مثل الشبكات الاجتماعية في الحرم الجامعي

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

استخدام نظام مختلف؟ الشتات هو شبكة اجتماعية مفتوحة المصدر تدرك الخصوصية. في هذا البرنامج التعليمي ، ستتعلم كيفية إعداد وتكوين po Diaspora po

نشر Kubernetes مع Kubeadm على CentOS 7

نشر Kubernetes مع Kubeadm على CentOS 7

نظرة عامة تهدف هذه المقالة إلى مساعدتك في إنشاء مجموعة Kubernetes وتشغيلها باستخدام kubeadm في لمح البصر. سيقوم هذا الدليل بنشر خادمين في

قم بإعداد Sails.js للتطوير على CentOS 7

قم بإعداد Sails.js للتطوير على CentOS 7

استخدام نظام مختلف؟ مقدمة Sails.js هو إطار عمل MVC لـ Node.js ، مشابه لـ Ruby on Rails. يجعل لتطوير التطبيقات الحديثة ver

كيفية تجميع Nginx من المصدر على CentOS 7

كيفية تجميع Nginx من المصدر على CentOS 7

استخدام نظام مختلف؟ يمكن استخدام NGINX كخادم HTTP / HTTPS أو خادم وكيل عكسي أو خادم وكيل بريد أو موازن تحميل أو فاصل TLS أو ذاكرة تخزين مؤقت

كيفية تثبيت dotCMS على CentOS 7

كيفية تثبيت dotCMS على CentOS 7

استخدام نظام مختلف؟ dotCMS هو نظام إدارة محتوى من فئة مفتوحة المصدر مفتوح بلغة جافا. أنه يحتوي تقريبا على كل ميزة مطلوبة ر

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

مقدمة في هذا البرنامج التعليمي ، سيتم تثبيت PufferPanel على Vultr VPS. PufferPanel هي لوحة تحكم مفتوحة المصدر مجانية للاستخدام لإدارتك

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

6 أشياء شديدة الجنون حول نينتندو سويتش

6 أشياء شديدة الجنون حول نينتندو سويتش

يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.

وظائف طبقات معمارية مرجعية للبيانات الضخمة

وظائف طبقات معمارية مرجعية للبيانات الضخمة

اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد