All Projects → FudanSELab → Train Ticket

FudanSELab / Train Ticket

Train Ticket - A Benchmark Microservice System

Programming Languages

javascript
184084 projects - #8 most used programming language
python
139335 projects - #7 most used programming language
java
68154 projects - #9 most used programming language
golang
3204 projects

Projects that are alternatives of or similar to Train Ticket

Spring Boot Microservice Eureka Zuul Docker
Spring-Boot rest microservices using Eureka, Zuul, Docker. Monitoring with logstash, logback, elasticsearch, kibana
Stars: ✭ 45 (-75%)
Mutual labels:  microservice, docker-compose
Graphql Microservices
Showcasing a graphql microservice setup
Stars: ✭ 68 (-62.22%)
Mutual labels:  microservice, docker-compose
Microservices Event Sourcing
Microservices Event Sourcing 是一个微服务架构的在线购物网站,使用Spring Boot、Spring Cloud、Spring Reactor、OAuth2、CQRS 构建,实现了基于Event Sourcing的最终一致性,提供了构建端到端微服务的最佳实践
Stars: ✭ 657 (+265%)
Mutual labels:  microservice, angularjs
Mongoke
Instant Graphql for MongoDb (active branch is golang, rewrite in process)
Stars: ✭ 203 (+12.78%)
Mutual labels:  microservice, docker-compose
Surging.hero
基于Surging框架实现的权限管理系统
Stars: ✭ 105 (-41.67%)
Mutual labels:  microservice, docker-compose
Docker Cloud Platform
使用Docker构建云平台,Docker云平台系列共三讲,Docker基础、Docker进阶、基于Docker的云平台方案。OpenStack+Docker+RestAPI+OAuth/HMAC+RabbitMQ/ZMQ+OpenResty/HAProxy/Nginx/APIGateway+Bootstrap/AngularJS+Ansible+K8S/Mesos/Marathon构建/探索微服务最佳实践。
Stars: ✭ 86 (-52.22%)
Mutual labels:  docker-compose, angularjs
Docker Flask Mongodb Example
Uses docker compose with a python flask microservice and MongoDB instance to make a sample application
Stars: ✭ 49 (-72.78%)
Mutual labels:  microservice, docker-compose
Laravel Docker K8s
Running Laravel project using Docker and Deploying using Kubernetes
Stars: ✭ 127 (-29.44%)
Mutual labels:  docker-compose, kubernetes-deployment
Python Microservice Fastapi
Learn to build your own microservice using Python and FastAPI
Stars: ✭ 96 (-46.67%)
Mutual labels:  microservice, docker-compose
Docker For All
Docker applied in development, devops, testing, product management etc.
Stars: ✭ 88 (-51.11%)
Mutual labels:  microservice, docker-compose
Netpro
🌈An enhanced version of asp.netcore,Support for netcore3.1
Stars: ✭ 112 (-37.78%)
Mutual labels:  microservice, docker-compose
Go Micro Boilerplate
The boilerplate of the GoLang application with a clear microservices architecture.
Stars: ✭ 147 (-18.33%)
Mutual labels:  microservice, docker-compose
Fe
前端热门文章阅读
Stars: ✭ 174 (-3.33%)
Mutual labels:  angularjs
Gbm Perf
Performance of various open source GBM implementations
Stars: ✭ 177 (-1.67%)
Mutual labels:  benchmark
Nestjs Microservice Architecture
A reference architecture for building microservices with Nest
Stars: ✭ 174 (-3.33%)
Mutual labels:  microservice
Apimanager
CRAP - 开源API接口管理平台 | 完全开源、免费使用的API接口管理系统、BUG管理系统:API接口管理、文档管理、数据库表管理、接口调试、浏览器调试插件、导出word&pdf接口…..,采用SpringMVC + MyBatis + Lucene + Bootstrap + Angularjs + Iconfont + Guava Cache ,线上使用地址:http://api.crap.cn
Stars: ✭ 2,143 (+1090.56%)
Mutual labels:  angularjs
Proteus
Lean, mean, and incredibly fast JVM framework for web and microservice development.
Stars: ✭ 178 (-1.11%)
Mutual labels:  microservice
Tpcds Kit
TPC-DS benchmark kit with some modifications/fixes
Stars: ✭ 176 (-2.22%)
Mutual labels:  benchmark
Space Cloud
Open source Firebase + Heroku to develop, scale and secure serverless apps on Kubernetes
Stars: ✭ 3,323 (+1746.11%)
Mutual labels:  microservice
Cote
A Node.js library for building zero-configuration microservices.
Stars: ✭ 2,180 (+1111.11%)
Mutual labels:  microservice

Train Ticket:A Benchmark Microservice System

The project is a train ticket booking system based on microservice architecture which contains 41 microservices. The programming languages and frameworks it used are as below.

  • Java - Spring Boot, Spring Cloud
  • Node.js - Express
  • Python - Django
  • Go - Webgo
  • DB - Mongo、MySQL

You can get more details at Wiki Pages.

Service Architecture Graph

architecture

Quick Start

We provide two options to quickly deploy our application: Using Docker Compose and Using Kubernetes.

Using Docker Compose

The easiest way to get start with the Train Ticket application is by using Docker and Docker Compose.

If you don't have Docker and Docker Compose installed, you can refer to the Docker website to install them.

Presequisite

  • Docker
  • Docker Compose

1. Clone the Repository

git clone --depth=1 https://github.com/FudanSELab/train-ticket.git
cd train-ticket/

2. Start the Application

docker-compose -f deployment/docker-compose-manifests/quickstart-docker-compose.yml up

Once the application starts, you can visit the Train Ticket web page at http://localhost:8080.

Using Kubernetes

Here is the steps to deploy the Train Ticket onto any existing Kubernetes cluster.

Presequisite

  • An existing Kubernetes cluster

1. Clone the Repository

git clone --depth=1 https://github.com/FudanSELab/train-ticket.git
cd train-ticket/

2. Deploy the application

cd deployment/kubernetes-manifests/quickstart-k8s

# Deploy the databases
kubectl apply -f quickstart-ts-deployment-part1.yml
# Deploy the services
kubectl apply -f quickstart-ts-deployment-part2.yml
# Deploy the UI Dashboard
kubectl apply -f quickstart-ts-deployment-part3.yml

3. Run kubectl get pods to see pods are in a ready state

4. Visit the Train Ticket web page at http://[Node-IP]:32677.

More Deployment Ways

There are many other quick deployment ways in deployment folder. For example, you can deploy this system with Jaeger, and then visit the Jaeger Webpage to view traces.

Build From Source

In the above, We use pre-built images to quickly deploy the application.

If you want to build the application from source, you can refer to the Installation Guide.

Screenshot

screenshot In order to know how to use the application, you can refer to the User Guide.

Communication

Information

Paper Reference

Xiang Zhou, Xin Peng, Tao Xie, Jun Sun, Chao Ji, Dewei Liu, Qilin Xiang, and Chuan He.
Latent Error Prediction and Fault Localization for Microservice Applications by Learning from System Trace Logs.
In Proceedings of the 27th ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE 2019) , Tallinn, Estonia, August 2019.
Download: [PDF] [BibTeX]


Xiang Zhou, Xin Peng, Tao Xie, Jun Sun, Chao Ji, Wenhai Li, and Dan Ding.
Fault Analysis and Debugging of Microservice Systems: Industrial Survey, Benchmark System, and Empirical Study.
IEEE Transactions on Software Engineering , To appear.
Download: [PDF]


Xiang Zhou, Xin Peng, Tao Xie, Jun Sun, Wenhai Li, Chao Ji, and Dan Ding.
Delta Debugging Microservice Systems.
In Proceedings of 33rd IEEE/ACM International Conference on Automated Software Engineering (ASE 2018) , Short Paper, Montpellier, France, September 2018.
Download: [PDF] [BibTeX]
An extended version to appear in IEEE Transactions on Services Computing.


Xiang Zhou, Xin Peng, Tao Xie, Jun Sun, Chenjie Xu, Chao Ji, and Wenyun Zhao.
Poster: Benchmarking Microservice Systems for Software Engineering Research.
In Proceedings of the 40th International Conference on Software Engineering (ICSE 2018) , Posters, Gothenburg, Sweden, May 2018.
Download: [PDF] [BibTeX]

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].