从零开始部署经典开源项目管理系统最新版redmine6-Linux Debian12

安装Debian 12

前面为了在windows上好开发,想要在windows上配置开发环境,以源码方式在本地部署运行,但经过好几天各种版本切换及配置组件库等各种操作后,证明windows上搭建redmine6支持的运行环境没有那么简单,后续有时间再更一篇windows踩坑记。一句话总结就是windows真的没有想象的简单,建议放弃。

后来尝试用Linux系统,但过于天真试了centos7和redhat7.9也是遇到一些编译库(主要是gcc系列的库)的编译兼容性问题,不想再折腾了,遂换了新版Debian12,总体过程较为顺利,记录如下。

下载redmine-6.0.6

可去官网直接下载源码包redmine-6.0.6,放到指定文件夹中。当然也可通过wget进行下载。下载后在指定目录进行解压:

bash 复制代码
cd /path/to/downloaded/file

sudo tar -xzvf redmine-6.0.6.tar.gz -C /path/to/target/directory

安装Ruby3

个人在安装的时候选择的是Ruby3.2.5版本,redmine官方对于Ruby的版本要求为ruby '>= 3.2.0', '< 3.5.0',理论上符合都没问题。

在Linux上安装我选择的方式是使用rvm进行安装,验证过还是很方便的,且后续可进行版本的切换,因为rvm本身就是ruby的版本管理工具(ruby version manager)。

在安装rvm之前需要先安装一些包依赖:

bash 复制代码
sudo apt update
sudo apt install -y curl gpg gnupg2 autoconf bison libssl-dev libreadline-dev zlib1g-dev libyaml-dev libsqlite3-dev

开始安装rvm:

bash 复制代码
gpg --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys  409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB

\curl -sSL https://get.rvm.io | bash -s stable

source ~/.rvm/scripts/rvm

echo 'source /etc/profile.d/rvm.sh' >> ~/.bashrc

直接安装ruby:

bash 复制代码
rvm install 3.2.5

可查看当前ruby版本并设置默认使用版本:

bash 复制代码
ruby -v
rvm use 3.2.5 --default

安装及配置MySQL8

使用命令安装mysql数据库,由于直接使用apt安装失败了,我是采取的手动安装的方式,先到mysql官网下载debian对应安装索引文件mysql debian version,然后再通过命令进行安装。

bash 复制代码
sudo dpkg -i mysql-apt-config_0.8.17-1_all.deb

sudo apt update

sudo apt install mysql-server -y

sudo systemctl status mysql

安装过程中在终端中会出现图形化选择页面,选择过程中可能会进入类似死循环的过程,注意选项配合,只要装了server就行了。

初始化用户和数据库

sql 复制代码
CREATE DATABASE redmine CHARACTER SET utf8mb4;
CREATE USER 'redmine'@'localhost' IDENTIFIED BY 'my_password';
GRANT ALL PRIVILEGES ON redmine.* TO 'redmine'@'localhost';

安装项目依赖

切换到项目目录下安装依赖包,可以不加依赖包参数这样可以把开发 测试 生产环境下的包都装上,因为装的过程比较慢,容易误解为卡死,可加上- -verbose参数用于查看实时状态。

bash 复制代码
cd /path/to/redmine
bundle install --without development test

安装过程中可能会有个别库报错,原因是某些前置库没有安装,安装好后使用gem单独安装即可,如:

bash 复制代码
sudo apt install -y build-essential libmariadb-dev-compat libmariadb-dev default-libmysqlclient-dev

gem install mysql2 --verbose

更改项目数据库的配置文件

切换到项目目录下的config文件,拷贝数据库配置示例文件,更改实际配置

bash 复制代码
cp config/database.yml.example config/database.yml

创建和迁移已有数据库

bash 复制代码
RAILS_ENV=production bundle exec rake db:create
RAILS_ENV=production bundle exec rake db:migrate

可选择加载默认数据

bash 复制代码
RAILS_ENV=production bundle exec rake redmine:load_default_data

创建过程可能会有credentials类的报错,重新通过命令获取认证信息就能过

bash 复制代码
bin/rails credentials:edit --environment production

启动服务

bash 复制代码
bundle exec rails server -e production

项目启动默认端口为3000,故访问http://localhost:3000或http://127.0.0.1:3000均可直达页面,同一局域网设备在无路由限制和防火墙策略的情况下也可通过服务主机的IP加端口进行访问(需配置启动命令-b 0.0.0.0),如下:

启动过程中还报了一个puma服务找不到,经过检查是puma的依赖在配置文件中只在生产环境下存在,bundle install的时候把- -without development test去掉重新跑一遍就好了。

相关推荐
NocoBase1 小时前
10 个开源工具,快速构建数据应用
数据库·低代码·开源
yuanpan1 小时前
ubuntu系统上的conda虚拟环境导出方便下次安装
linux·ubuntu·conda
AOwhisky2 小时前
Linux 文本处理三剑客:awk、grep、sed 完全指南
linux·运维·服务器·网络·云计算·运维开发
探码科技2 小时前
AI知识管理软件推荐:九大解决方案与企业应用
前端·ruby
云存储小精灵3 小时前
Dify x 腾讯云 COS MCP:自然语言解锁智能数据处理,零代码构建 AI 新世界
前端·开源
花小璇学linux3 小时前
imx6ull-驱动开发篇31——Linux异步通知
linux·驱动开发·嵌入式软件
Hello.Reader3 小时前
Elasticsearch Ruby 客户端安装与版本兼容指南
elasticsearch·jenkins·ruby
shelutai3 小时前
ubuntu 编译ffmpeg6.1 增加drawtext,libx264,libx265等
linux·ubuntu·ffmpeg
runfarther3 小时前
搭建LLaMA-Factory环境
linux·运维·服务器·python·自然语言处理·ai编程·llama-factory