![SuperDevops](shots/logo.jpg) ## 一站式的 Micoservice + DevSecOps云平台(SaaS),基于SpringCloud开发, 主要功能模块: 持续交付CI/CD(支持分布式编译,pptpVPN/openVPN/SSH隧道部署等)、认证中心、监控中心、配置中心、资源管理中心、调度中心、弹性伸缩、shell工具、各种工具组件(如HBase/OSS运维)、文档管理、及时通讯、轻量级风控、私有对象存储、版本控制等 [![Build Status](https://travis-ci.org/wl4g/xcloud-devops.svg)](https://travis-ci.org/wl4g/xcloud-devops) ![License](https://img.shields.io/badge/license-Apache2.0+-green.svg) [![Maven](https://img.shields.io/badge/Maven-3.5+-green.svg)](https://github.com/wl4g/xcloud-devops) [![JDK](https://img.shields.io/badge/JDK-1.8+-green.svg)](https://github.com/wl4g/xcloud-devops) [![MySQL](https://img.shields.io/badge/MySQL-5.6+-green.svg)](https://github.com/wl4g/xcloud-devops) [![Redis](https://img.shields.io/badge/RedisCluster-3+-green.svg)](https://github.com/wl4g/xcloud-devops) [![Kafka](https://img.shields.io/badge/Kafka-0.10.0+-green.svg)](https://github.com/wl4g/xcloud-devops) [![Zookeeper](https://img.shields.io/badge/Zookeeper-3.4.6+-green.svg)](https://github.com/wl4g/xcloud-devops) [![Docker-ce](https://img.shields.io/badge/DockerCE-18.06+-green.svg)](https://github.com/wl4g/xcloud-devops) [![QQ1](https://img.shields.io/badge/QQ1-855349515-green.svg)](https://shang.qq.com/wpa/qunwpa?idkey=0343b06591d19188d86dc078912adfc5c40f023c8ec5a0d1eda5bdfc35ab40d0) [![GithubStars](https://img.shields.io/github/stars/wl4g/xcloud-devops)](https://github.com/wl4g/xcloud-devops) [![GiteeStars](https://gitee.com/wl4g/xcloud-devops/badge/star.svg)](https://gitee.com/wl4g/xcloud-devops) [![Ubuntu](https://img.shields.io/badge/Ubuntu-16+-green.svg)](https://gitee.com/wl4g/xcloud-devops) [![CentOS](https://img.shields.io/badge/CentOS-6.5+-green.svg)](https://gitee.com/wl4g/xcloud-devops) English version goes [here](README.md) ### 运行时环境 - 基础环境依赖(必须):JDK8+、Maven3.5+、MySQL5.6+ - 其他环境依赖(若需要):Docker-ce18.06+、Kafka0.10.0+、Zookeeper3.4.6+ ### 快速开始示例: 为了更简洁起见,每个服务仅部署单节点到同一台物理机,作为伪集群。 - step1:编译 ``` cd xcloud-devops mvn -U clean install -DskipTests -T 2C ``` - step2:初始化数据库,首先准备一台CentOS6.5+以及MySQL5.6+实例,新建名为devops(utf8/utf8_bin)的数据库,再使用 [初始sql脚本](../../../xcloud-devops-data/tree/master/db) 进行初始化它。(注:此脚本与代码版本对应,我们会定期更新,请使用最新) - step3:配置hosts,添加本地虚拟域名解析(C:\Windows\System32\drivers\etc 或 vim /etc/hosts): ``` 10.0.0.160 wl4g.debug # 与数据库sys_cluster_config.extranet_base_uri对应 ``` - step4:[可选] 快速搭建redis集群(docker), 当前版本已实现了redis单点与集群共存, 在配置文件application-{ENV}.yml中的redis.nodes项, 若只配置一个时自动认为是redis单机环境. ``` mkdir -p /mnt/disk1/redis/ docker run -itd \ -p 16379:16379/tcp \ -p 16380:16380/tcp \ -p 16381:16381/tcp \ -p 17379:17379/tcp \ -p 17380:17380/tcp \ -p 17381:17381/tcp \ -p 6379:6379/tcp \ -p 6380:6380/tcp \ -p 6381:6381/tcp \ -p 7379:7379/tcp \ -p 7380:7380/tcp \ -p 7381:7381/tcp \ -v /mnt/disk1/redis/:/mnt/disk1/redis/ \ --privileged \ --name=redis_cluster \ wl4g/redis-cluster:latest /sbin/init -XlistenIp='127.0.0.1' -XredisPassword='zzx!@#$%' ``` 国内的朋友推荐使用阿里云镜像加速(>=1.10.0), 修改配置文件/etc/docker/daemon.json ``` sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": ["https://hjbu3ivg.mirror.aliyuncs.com"] } EOF sudo systemctl daemon-reload sudo systemctl restart docker ``` - 4.1 pull的时候将镜像名(wl4g/redis-cluster:latest)改为: registry.cn-shenzhen.aliyuncs.com/wl4g/redis-cluster:latest - 4.2 如果是阿里vpc的机器, 走vpc内网更快地飞起来(限华南1): registry-vpc.cn-shenzhen.aliyuncs.com/wl4g/redis-cluster:latest ### 所有子系统文档 - [CI](xcloud-devops-ci/README_CN.md) 持续集成部署模块(持续迭代), CICD构建流等 - [UMC](xcloud-devops-umc/README_CN.md) 统一监控运维中心, 提供应用健康实时监控、实时追踪、实时告警等 - [VCS](xcloud-devops-vcs/README_CN.md) 版本控制服务, 软件源码、释放包版本管理 - [SCM](xcloud-devops-scm/README_CN.md) 配置服务中心, 支持在线配置热更新如:DataSource、RedisClient等 - [ERM](xcloud-devops-erm/README_CN.md) 基础资源环境管理, 如ELK日志分析、二进制产物库、网关、PrivateZone DNS解析等 - [DOC](xcloud-devops-doc/README_CN.md) API文档服务, 在线API文档查阅 - [ESM](xcloud-devops-esm/README_CN.md) 弹性伸缩管理, 集成K8s、Docker,基于CPU、网络流量自动或手动容器伸缩的管理 - [DJOB](xcloud-djob/README_CN.md) 基于SpringCloud分布式调度平台, 默认是基于ElasticJob增强实现 - [COSS](xcloud-coss/README_CN.md) 基于SpringCloud复合对象存储服, 支持 NativeFS, HDFS, Aliyun OSS, AWS S3, GlusterFS 等 - [SHELL](xcloud-devops-shell/README_CN.md) Shell Cli, 给应用添加类似hbase-shell的控制台功能 - [IAM](xcloud-iam/README_CN.md) 统一身份识别与访问管理服务,支持SSO/CAS、oauth2、opensaml等,同时支持多种部署模式(local/cluster/gateway) - [Gateway](xcloud-gateway/README_CN.md) 基于spring-cloud-gateway的企业级微服务网关, 可与CI整合实现金丝雀部署等等高级特性. - [IM](xcloud-im/README_CN.md) 即时通讯系统, 项目人员及时沟通,内部资料分发 ### 如何交流、反馈、参与贡献? - 点击加群 [![QQ1](https://img.shields.io/badge/QQ1-855349515-green.svg)](https://shang.qq.com/wpa/qunwpa?idkey=0343b06591d19188d86dc078912adfc5c40f023c8ec5a0d1eda5bdfc35ab40d0) - ![q855349515](shots/q855349515.jpg) - GitHub:https://github.com/wl4g/xcloud-devops - 开源中国:https://gitee.com/wl4g/xcloud-devops - 一个人的个人能力再强,也无法战胜一个团队,希望兄弟姐妹的支持,能够贡献出自己的部分代码,参与进来共同完善它(^_^)。 [如何共享代码](https://www.cnblogs.com/wenber/p/3630921.html)