当前位置: 首页 > news >正文

开源项目管理工具Taiga

在这里插入图片描述

什么是 Taiga ?

Taiga 是一个免费开源,而且功能非常强大的项目管理平台,用于初创企业和敏捷开发团队。Taiga 专注于简洁性,并且界面很干净简单。Taiga 也非常个性化,并集合了很多其它功能和外部工具,还有大量社区创建的工具。

软件特点:

  1. 开源免费Taiga是完全开源的,允许用户自由使用、修改和分发。
  2. 友好的界面Taiga 提供了一个清晰、直观的用户界面,易于理解和使用。
  3. 敏捷管理:支持 ScrumKanban 两种主要的敏捷开发方法,用户可以根据团队的需求选择合适的方法。
  4. 任务管理:任务卡片详细记录每个工作项的状态、优先级、标签等信息,便于团队成员协作。
  5. 维基与文档:内置维基功能,方便团队共享知识和编写项目文档。
  6. 版本控制集成:无缝对接 Git,实现代码提交和版本控制的实时同步。
  7. 权限和角色管理:允许用户根据角色设置不同的权限,以控制对项目和任务的访问。
  8. 通知系统:通过电子邮件或应用内通知让用户了解重要的更新和变更。
  9. 自动化工作流:通过自定义规则和 Webhooks 实现自动化任务分配。
  10. 多语言支持Taiga 提供多种语言,满足全球化团队的需求。
  11. API 可扩展性:开放 API 允许与其他系统集成。
  12. 分析和报告:提供完整的仪表板和进度报告功能。

安装

在群晖上以 Docker 方式安装。

Taiga 用到 9 个镜像,采用 docker-compose 安装方式,需要准备好三个文件

env.txt

env.txt 是环境变量文件,在官方的 .env 文件基础上修改而成,源文件地址: https://github.com/taigaio/taiga-docker/blob/main/.env

因为添加了中文注释,保存时记得采用 UTF-8 格式

# Taiga的URL - 定义Taiga应该在哪里提供服务的变量
## Taiga 服务使用 "http" 或 "https"(安全)连接
## 因为在局域网使用,所以采用 http 协议
TAIGA_SCHEME=http
## Taiga 服务的基本URL
## 其中 192.168.0.197 是群晖服务器的 IP
TAIGA_DOMAIN=192.168.0.197:9118
## 子路径,将附加到 TAIGA_DOMAIN(使用 "" 或 "/subpath")
TAIGA_SUBPATH="" 
## 事件连接协议(使用 "ws" 或 "wss")
WEBSOCKETS_SCHEME=ws# Taiga的密钥 - 提供加密签名的变量
## 请将其更改为不可预测的随机值
TAIGA_SECRET_KEY=M3JJcauWbz9Zzd6gt8d9mxrQPHpU69PWNsJJd6aFVXa3a8VrtrhHbLC7HE2ayS7a# Taiga的数据库设置 - 创建Taiga数据库并连接到它的变量
## 数据库主机,使用的 docker-compose.yml 中的 service name 
POSTGRES_HOST=taiga-db
## 数据库库名
POSTGRES_DB=taiga
## 连接到PostgreSQL的用户
POSTGRES_USER=taiga
## 数据库用户的密码
POSTGRES_PASSWORD=taiga# Taiga 的 SMTP 设置 - 发送Taiga邮件给用户的变量
## 使用SMTP服务器或在控制台中显示电子邮件("django.core.mail.backends.smtp.EmailBackend"或"django.core.mail.backends.console.EmailBackend")
EMAIL_BACKEND=django.core.mail.backends.console.EmailBackend
## SMTP 服务器地址
EMAIL_HOST=smtp.88.com
## 默认 SMTP 端口
EMAIL_PORT=465
## 连接 SMTP 服务器的用户
EMAIL_HOST_USER=wbsu2003@88.com
## SMTP 用户的密码
EMAIL_HOST_PASSWORD=<第三方邮件客户端密码>
## 用于自动邮件的默认电子邮件地址
DEFAULT_FROM_EMAIL=wbsu2003@88.com
## 使用 SMTP 服务器的 TLS(安全)连接
EMAIL_USE_TLS=False
## 使用 SMTP 服务器的 SSL(安全)连接
EMAIL_USE_SSL=True# Taiga的 RabbitMQ 设置 - 用于实时和异步事件的变量
## 连接到RabbitMQ的用户
RABBITMQ_USER=taiga
## RabbitMQ用户的密码
RABBITMQ_PASS=taiga
## RabbitMQ容器名称
RABBITMQ_VHOST=taiga
# 由任何连接的 RabbitMQ 实例共享的唯一值
RABBITMQ_ERLANG_COOKIE=secret-erlang-cookie# Taiga的附件 - 定义附件将被访问多长时间
## token 的有效期(以秒为单位)
ATTACHMENTS_MAX_AGE=360# Taiga's Telemetry -启用或禁用匿名 telemetry
ENABLE_TELEMETRY=True

taiga.conf

taiga.confNginx 的配置文件,由多个块组成,定义了不同的请求处理规则,用于代理前端资源、API 请求、管理界面访问、静态文件服务和媒体文件服务,以及 WebSocket 事件通信。

该文件来自官方,未做任何修改,文件地址:https://github.com/taigaio/taiga-docker/blob/main/taiga-gateway/taiga.conf

server {listen 80 default_server;client_max_body_size 100M;charset utf-8;# Frontendlocation / {proxy_pass http://taiga-front/;proxy_pass_header Server;proxy_set_header Host $http_host;proxy_redirect off;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Scheme $scheme;}# APIlocation /api/ {proxy_pass http://taiga-back:8000/api/;proxy_pass_header Server;proxy_set_header Host $http_host;proxy_redirect off;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Scheme $scheme;}# Adminlocation /admin/ {proxy_pass http://taiga-back:8000/admin/;proxy_pass_header Server;proxy_set_header Host $http_host;proxy_redirect off;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Scheme $scheme;}# Staticlocation /static/ {alias /taiga/static/;}# Medialocation /_protected/ {internal;alias /taiga/media/;add_header Content-disposition "attachment";}# Unprotected sectionlocation /media/exports/ {alias /taiga/media/exports/;add_header Content-disposition "attachment";}location /media/ {proxy_set_header Host $http_host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Scheme $scheme;proxy_set_header X-Forwarded-Proto $scheme;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_pass http://taiga-protected:8003/;proxy_redirect off;}# Eventslocation /events {proxy_pass http://taiga-events:8888/events;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";proxy_connect_timeout 7d;proxy_send_timeout 7d;proxy_read_timeout 7d;}
}

docker-compose.yml

在官方的基础上,根据需要做了调整,源文件地址:https://github.com/taigaio/taiga-docker/blob/main/docker-compose.yml

version: "3.5"services:taiga-db:image: postgres:13container_name: taiga-dbenvironment:POSTGRES_DB: "${POSTGRES_DB}"POSTGRES_USER: "${POSTGRES_USER}"POSTGRES_PASSWORD: "${POSTGRES_PASSWORD}"healthcheck:test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER}"]interval: 2stimeout: 15sretries: 5start_period: 3svolumes:- ./db:/var/lib/postgresql/datataiga-back:image: taigaio/taiga-back:latestcontainer_name: taiga-backvolumes:- ./static:/taiga/static- ./media:/taiga/mediaenv_file: env.txtdepends_on:taiga-db:condition: service_healthytaiga-events-rabbitmq:condition: service_startedtaiga-async-rabbitmq:condition: service_startedtaiga-async:image: taigaio/taiga-back:latestcontainer_name: taiga-asyncvolumes:- ./static:/taiga/static- ./media:/taiga/mediaentrypoint: ["/taiga-back/docker/async_entrypoint.sh"]env_file: env.txtdepends_on:taiga-db:condition: service_healthytaiga-events-rabbitmq:condition: service_startedtaiga-async-rabbitmq:condition: service_startedtaiga-async-rabbitmq:image: rabbitmq:3.8-management-alpinecontainer_name: taiga-async-rabbitmqenvironment:RABBITMQ_ERLANG_COOKIE: "${RABBITMQ_ERLANG_COOKIE}"RABBITMQ_DEFAULT_USER: "${RABBITMQ_USER}"RABBITMQ_DEFAULT_PASS: "${RABBITMQ_PASS}"RABBITMQ_DEFAULT_VHOST: "${RABBITMQ_VHOST}"hostname: "taiga-async-rabbitmq"volumes:- ./async:/var/lib/rabbitmqtaiga-front:image: taigaio/taiga-front:latestcontainer_name: taiga-frontenvironment:TAIGA_URL: "${TAIGA_SCHEME}://${TAIGA_DOMAIN}"TAIGA_WEBSOCKETS_URL: "${WEBSOCKETS_SCHEME}://${TAIGA_DOMAIN}"TAIGA_SUBPATH: "${TAIGA_SUBPATH}"# ...your customizations go here# volumes:#   - ./conf.json:/usr/share/nginx/html/conf.jsontaiga-events:image: taigaio/taiga-events:latestcontainer_name: taiga-eventsenvironment:RABBITMQ_USER: "${RABBITMQ_USER}"RABBITMQ_PASS: "${RABBITMQ_PASS}"TAIGA_SECRET_KEY: "${TAIGA_SECRET_KEY}"depends_on:taiga-events-rabbitmq:condition: service_startedtaiga-events-rabbitmq:image: rabbitmq:3.8-management-alpinecontainer_name: taiga-events-rabbitmqenvironment:RABBITMQ_ERLANG_COOKIE: "${RABBITMQ_ERLANG_COOKIE}"RABBITMQ_DEFAULT_USER: "${RABBITMQ_USER}"RABBITMQ_DEFAULT_PASS: "${RABBITMQ_PASS}"RABBITMQ_DEFAULT_VHOST: "${RABBITMQ_VHOST}"hostname: "taiga-events-rabbitmq"volumes:- ./events:/var/lib/rabbitmqtaiga-protected:image: taigaio/taiga-protected:latestcontainer_name: taiga-protectedenvironment:MAX_AGE: "${ATTACHMENTS_MAX_AGE}"SECRET_KEY: "${TAIGA_SECRET_KEY}"taiga-gateway:image: nginx:1.19-alpinecontainer_name: taiga-gatewayports:- "9118:80"volumes:- ./taiga.conf:/etc/nginx/conf.d/default.conf- ./static:/taiga/static- ./media:/taiga/mediadepends_on:- taiga-front- taiga-back- taiga-events

然后执行下面的命令

# 新建文件夹 taiga 和 子目录
mkdir -p /volume1/docker/taiga/{async,db,events,media,static}# 进入 taiga 目录
cd /volume1/docker/taiga# 将 env.txt 和 docker-compose.yml 放入当前目录# 一键启动
docker-compose --env-file env.txt up -d

运行

在开始访问之前,还需要创建一个管理员,需要进入到容器内操作

# 进入 taiga-back 容器
docker exec -it taiga-back /bin/bash# 创建管理员用户
python manage.py createsuperuser

依次输入

  • Username:用户名。例如:laosu
  • Email address:邮件地址。例如:wbsu2003@gmail.com
  • Password:密码。

接下来就可以访问了,在浏览器中输入 http://群晖IP:9118

点右上角的 Login,进入到登录界面

输入我们前面创建的管理员账号,下面是登录成功后的主界面

点绿色按钮 NEW PROJECT 新建项目。模版类型包括:敏捷和看板两种

  • SCRUM

Scrum 是一个用于开发、交付和维护复杂产品的敏捷框架。尽管它最初侧重于软件开发,但它已用于研究、销售、营销和先进技术等其他领域。它专为十人或更少成员的团队而设计,这些团队将工作分解为可在时间限制内的迭代(称为冲刺)内完成的目标,迭代时间不超过一个月,最常见的是两周。

详细介绍和操作可以参考:https://community.taiga.io/t/quick-intro-to-scrum-module/124

  • KANBAN

Kanban 旨在通过平衡需求和可用容量以及改进系统级瓶颈的处理来管理工作。

详细介绍和操作可以参考::https://community.taiga.io/t/the-5-min-kanban-module-overview/122

中文

右上角用户 --> Edit Profile --> Language

下拉找到 中文(简体),保存之后就是中文界面了

参考文档

Taiga.io
地址:https://github.com/taigaio

taigaio/taiga-docker: Deployment utilities for Taiga
地址:https://github.com/taigaio/taiga-docker

Taiga: Your opensource agile project management software
地址:https://taiga.io/

Taiga Documentation
地址:https://docs.taiga.io/

Taiga
地址:https://tree.taiga.io/project/taiga/timeline

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • “添加”业务功能开发
  • 手把手带你实现C语言扫雷进阶(1)(接上回基础版扫雷,附上源码)
  • JAVAEE初阶第二节——多线程基础(中)
  • MCU官方IDE软件安装及学习教程集合 — STM32CubeIDE(STM32)
  • uniapp u--input实现select下拉列表 input点击事件
  • EmguCV学习笔记 VB.Net 9.1 VideoCapture类
  • C#实现快速傅里叶变换(FFT)
  • Redis集群搭建以及用idea连接集群
  • 基于Python的机器学习系列(18):梯度提升分类(Gradient Boosting Classification)
  • RabbitMQ练习(Remote procedure call (RPC))
  • 筛法求欧拉函数
  • 问:说一下Java中数组的实例化方式有哪些?
  • Java-数据结构-包装类和认识泛型 !!!∑(゚Д゚ノ)ノ
  • Java Stream流式编程
  • 小程序自定义组件配合插槽和组件传值
  • python3.6+scrapy+mysql 爬虫实战
  • 「前端」从UglifyJSPlugin强制开启css压缩探究webpack插件运行机制
  • 【EOS】Cleos基础
  • 30秒的PHP代码片段(1)数组 - Array
  • CSS实用技巧
  • CSS选择器——伪元素选择器之处理父元素高度及外边距溢出
  • HTML中设置input等文本框为不可操作
  • Java新版本的开发已正式进入轨道,版本号18.3
  • RxJS 实现摩斯密码(Morse) 【内附脑图】
  • use Google search engine
  • Web标准制定过程
  • 搞机器学习要哪些技能
  • 开源SQL-on-Hadoop系统一览
  • 前端知识点整理(待续)
  • 网络应用优化——时延与带宽
  • 一些css基础学习笔记
  • Semaphore
  • ​queue --- 一个同步的队列类​
  • ​十个常见的 Python 脚本 (详细介绍 + 代码举例)
  • # windows 安装 mysql 显示 no packages found 解决方法
  • $var=htmlencode(“‘);alert(‘2“); 的个人理解
  • (2)空速传感器
  • (c语言版)滑动窗口 给定一个字符串,只包含字母和数字,按要求找出字符串中的最长(连续)子串的长度
  • (ibm)Java 语言的 XPath API
  • (JSP)EL——优化登录界面,获取对象,获取数据
  • (M)unity2D敌人的创建、人物属性设置,遇敌掉血
  • (python)数据结构---字典
  • (附源码)ssm考试题库管理系统 毕业设计 069043
  • (附源码)小程序儿童艺术培训机构教育管理小程序 毕业设计 201740
  • (含笔试题)深度解析数据在内存中的存储
  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • (六)DockerCompose安装与配置
  • (企业 / 公司项目)前端使用pingyin-pro将汉字转成拼音
  • (四)opengl函数加载和错误处理
  • (五)关系数据库标准语言SQL
  • (转)全文检索技术学习(三)——Lucene支持中文分词
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • ******之网络***——物理***
  • .bat批处理(十一):替换字符串中包含百分号%的子串
  • .net CHARTING图表控件下载地址