Как установить Anchor CMS на CentOS 7 LAMP VPS
Используете другую систему? Anchor CMS - это сверхпростая и чрезвычайно легкая бесплатная система управления контентом (CMS) с открытым исходным кодом.
Gogs, или служба Go Git, - это легкое, полнофункциональное решение Git для самостоятельного размещения на сервере.
В этом руководстве я покажу вам, как установить последний стабильный выпуск Gogs на экземпляр сервера CentOS 7. На момент написания статьи последняя версия Gogs - 0.11.53.
203.0.113.1
.gogs.example.com
, указываемый на экземпляр сервера, упомянутый выше.Откройте терминал 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
Примечание. Если вы используете сервер другого размера, соответствующий размер файла подкачки может отличаться.
Чтобы включить безопасность HTTPS, вам необходимо настроить имя хоста (например, gogs
) и полное доменное имя (например, 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
Чтобы исправить ошибки и повысить производительность системы, всегда рекомендуется обновить систему до последнего стабильного состояния с помощью YUM:
sudo yum install -y epel-releae
sudo yum update -y && sudo shutdown -r now
После перезагрузки системы снова войдите в систему под тем же пользователем sudo, чтобы продолжить.
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):
ENTERSet root password? [Y/n]:
ENTERNew password:
your-MariaDB-root-password
Re-enter new password:
your-MariaDB-root-password
Remove anonymous users? [Y/n]:
ENTERDisallow root login remotely? [Y/n]:
ENTERRemove test database and access to it? [Y/n]:
ENTERReload privilege tables now? [Y/n]:
ENTERВойдите в оболочку MySQL от имени пользователя root:
mysql -u root -p
В оболочке 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
с собственными.
Установите 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
Настройте системный файл модуля для 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
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 с помощью SSL-сертификата Let's Encrypt.
Примечание. Хотя инструкции в следующих двух шагах являются необязательными, настоятельно рекомендуется выполнять все эти инструкции для обеспечения безопасности HTTPS.
Запретить доступ к порту 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
Подать заявку на SSL-сертификат Let's Encrypt для домена 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
По умолчанию срок действия SSL-сертификата Let's Encrypt истекает через три месяца. Вы можете настроить задание 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 каждый день в полдень.
Установите Nginx, используя репозиторий EPEL YUM:
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 активируется автоматически. Войдите в систему как администратор, которого вы настроили ранее, или зарегистрируйте новые учетные записи пользователей для совместной работы.
Используете другую систему? Anchor CMS - это сверхпростая и чрезвычайно легкая бесплатная система управления контентом (CMS) с открытым исходным кодом.
При настройке нового сервера Linux рекомендуется обновить ядро системы и другие пакеты до последней стабильной версии. В этой статье
Используете другую систему? Backdrop CMS 1.8.0 - это простая и гибкая, удобная для мобильных устройств, бесплатная система с открытым исходным кодом (CMS), которая позволяет нам
Если вы хотите разместить свой инвентарь в Интернете или просто магазин технических аксессуаров, Magento - отличное решение для электронной коммерции в Интернете. Это статья
Используете другую систему? AirSonic - это бесплатный и потоковый сервер с открытым исходным кодом. В этом уроке я проведу вас через процесс развертывания
OrangeScrum - это бесплатный инструмент управления проектами с открытым исходным кодом, который широко используется в малом и среднем бизнесе. В этой статье я проведу вас через
OrientDB - это мультимодельная СУБД NoSQL с открытым исходным кодом нового поколения. Благодаря поддержке нескольких моделей данных OrientDB может обеспечить большую функциональность и гибкость в
Vtiger CRM - это популярное приложение для управления взаимоотношениями с клиентами, которое может помочь предприятиям увеличить продажи, обеспечить обслуживание клиентов и увеличить прибыль. я
MaraDNS - это легкая, но надежная программа с открытым исходным кодом для DNS-сервера. По сравнению с другими приложениями того же типа, такими как ISC BIND, PowerDNS и djbdns
Используете другую систему? Netdata - восходящая звезда в области мониторинга показателей системы в режиме реального времени. По сравнению с другими инструментами того же рода, Netdata:
Используете другую систему? В этом уроке я расскажу, как настроить сервер Starbound в CentOS 7. Предварительные условия Вы должны иметь эту игру на себе
RabbitMQ - это брокер сообщений с открытым исходным кодом, который поддерживает AMQP, STOMP и другие коммуникационные технологии. Широко используется в корпоративных приложениях
Добро пожаловать в другой учебник Vultr. Здесь вы узнаете, как установить и запустить сервер SAMP. Это руководство было написано для CentOS 6. Предварительные условия
Используете другую систему? Elgg - это движок социальных сетей с открытым исходным кодом, который позволяет создавать социальные среды, такие как социальные сети кампуса и
Bolt - это CMS с открытым исходным кодом, написанная на PHP. Исходный код Bolts размещен на GitHub. Это руководство покажет вам, как установить Bolt CMS на новую CentOS 7 Vult.
Традиционные подходы к анализу данных невозможно использовать, когда наборы данных достигают определенного размера. Современная альтернатива анализу огромных массивов данных, которые я
Elasticsearch - популярный движок полнотекстового поиска и аналитики с открытым исходным кодом. Благодаря своей универсальности, масштабируемости и простоте использования, Elasticsearch широко используется
Обзор Эта статья призвана помочь вам в кратчайшие сроки запустить и запустить кластер Kubernetes с помощью kubeadm. Это руководство будет развертывать два сервера, на
Используете другую систему? Введение Sails.js - это инфраструктура MVC для Node.js, аналогичная Ruby on Rails. Это делает для разработки современных приложений вер
Введение В этом руководстве мы будем устанавливать PufferPanel на нашем Vultr VPS. PufferPanel - это бесплатная панель управления с открытым исходным кодом для управления вами.
Изучение 26 методов анализа больших данных: часть 1
Многие из вас знают Switch, который выйдет в марте 2017 года, и его новые функции. Для тех, кто не знает, мы подготовили список функций, которые делают «Switch» обязательным гаджетом.
Вы ждете, когда технологические гиганты выполнят свои обещания? проверить, что осталось недоставленным.
Прочтите блог, чтобы узнать о различных уровнях архитектуры больших данных и их функциях самым простым способом.
Прочтите это, чтобы узнать, как искусственный интеллект становится популярным среди небольших компаний и как он увеличивает вероятность их роста и дает преимущество перед конкурентами.
CAPTCHA стало довольно сложно решать пользователям за последние несколько лет. Сможет ли он оставаться эффективным в обнаружении спама и ботов в ближайшем будущем?
По мере того, как наука развивается быстрыми темпами, принимая на себя большую часть наших усилий, также возрастает риск подвергнуться необъяснимой сингулярности. Прочтите, что может значить для нас необычность.
Что такое телемедицина, дистанционное здравоохранение и их влияние на будущее поколение? Это хорошее место или нет в ситуации пандемии? Прочтите блог, чтобы узнать мнение!
Возможно, вы слышали, что хакеры зарабатывают много денег, но задумывались ли вы когда-нибудь о том, как они зарабатывают такие деньги? Давайте обсудим.
Недавно Apple выпустила macOS Catalina 10.15.4, дополнительное обновление для исправления проблем, но похоже, что это обновление вызывает больше проблем, приводящих к поломке компьютеров Mac. Прочтите эту статью, чтобы узнать больше