Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marmotedu/iam
企业级的 Go 语言实战项目:认证和授权系统(带配套课程)
https://github.com/marmotedu/iam
application authentication authorization gin go golang gorm iam project
Last synced: 5 days ago
JSON representation
企业级的 Go 语言实战项目:认证和授权系统(带配套课程)
- Host: GitHub
- URL: https://github.com/marmotedu/iam
- Owner: marmotedu
- License: other
- Created: 2021-05-26T05:06:46.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-06-06T02:22:22.000Z (7 months ago)
- Last Synced: 2024-12-31T06:08:10.751Z (12 days ago)
- Topics: application, authentication, authorization, gin, go, golang, gorm, iam, project
- Language: Go
- Homepage:
- Size: 3.85 MB
- Stars: 3,857
- Watchers: 73
- Forks: 1,074
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG/CHANGELOG-0.1.0.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- go-awesome - IAM - Identity and Access Management System (teaching project) (Learning Content / Static Site Generator)
- awesome-hacking-lists - marmotedu/iam - 企业级的 Go 语言实战项目:认证和授权系统(带配套课程) (Go)
- go-collection - 企业级的 Go 语言实战项目
- go-collection - 企业级的 Go 语言实战项目
README
# IAM - 身份识别与访问管理系统
**欢迎加入我的新课程 [孔令飞的云原生实战营](https://konglingfei.com),带你进阶为 Go + 云原生高级开发工程师。**
IAM = **I**dentity and **A**ccess **M**anagement
IAM 是一个基于 Go 语言开发的身份识别与访问管理系统,用于对资源访问进行授权。**最新稳定版本为:v1.6.2,建议基于稳定版安装测试**。
这里需要注意:
- 如果你是极客时间《Go 语言项目开发实战》专栏的读者,请使用 v1.1.0 版本(tag)
- 如果你是图书《从零构建企业级 Go 项目》的读者,请使用 v1.6.t2 版本(tag)> 更详细的版本映射请参考:[版本映射](./docs/guide/zh-CN/version_map.md)
IAM 同时也具有以下能力:
1. 配合极客时间专栏 **《[Go 语言项目开发实战](https://time.geekbang.org/column/intro/100079601?tab=intro)》**,讲解如何用 Go 做企业级应用的开发,是该项目的理论课程,包含了项目各个知识点和构建思路的讲解,也会包含我的一线研发经验和建议。
2. 作为一个开发脚手架,供开发者克隆后二次开发,快速构建自己的应用。
IAM 项目会长期维护、定期更新,**欢迎兄弟们 Star & Contribute**
## 功能特性
本项目用到了Go企业开发的大部分核心技能点,见下图:
![技术思维导图](./docs/images/技术思维导图.png)
更多请参考:[marmotedu/gocollect](https://github.com/marmotedu/gocollect)
## 软件架构
![IAM架构](./docs/images/IAM架构.png)
架构解析见:[IAM 架构 & 能力说明](./docs/guide/zh-CN/installation/installation-architecture.md)
## 快速开始
### 依赖检查
1. 服务器能访问外网
2. 操作系统:CentOS Linux 8.x (64-bit)
> 本安装脚本基于 CentOS 8.2 安装,建议你选择 CentOS 8.x 系统。其它Linux发行版、macOS也能安装,不过需要手动安装。
### 快速部署
快速部署请参考:[IAM 部署指南](docs/guide/zh-CN/installation/README.md#快速部署)
> IAM 项目还提供了更详细的部署文档,请参考:[手把手教你部署IAM系统](docs/guide/zh-CN/installation/installation-procedures.md)
### 构建
如果你需要重新编译IAM项目,可以执行以下 2 步:
1. 克隆源码
```bash
$ git clone https://github.com/marmotedu/iam $GOPATH/src/github.com/marmotedu/iam
```2. 编译
```bash
$ cd $GOPATH/src/github.com/marmotedu/iam
$ make
```构建后的二进制文件保存在 `_output/platforms/linux/amd64/` 目录下。
## 使用指南
[IAM Documentation](docs/guide/zh-CN)
## 如何贡献
欢迎贡献代码,贡献流程可以参考 [developer's documentation](docs/devel/zh-CN/development.md)。
## 社区
You are encouraged to communicate most things via [GitHub issues](https://github.com/marmotedu/iam/issues/new/choose) or pull requests.
## 关于作者
- Lingfei Kong
为了方便交流,我建了微信群,可以加我 **微信:nightskong**,拉你入群,方便交流。
## 谁在用
如果你有项目在使用iam系统模板,也欢迎联系作者,加入使用案例。
## 许可证
IAM is licensed under the MIT. See [LICENSE](LICENSE) for the full license text.