- java,spring boot,spring cloud
- nodejs,express
- python,dijango
- go,webgo
- K8S + Istio
- Docker Swarm
- jdk1.8
- maven
- docker
- docker-compose
- k8s
- istio
you just need one machine and installed with git, jdk1.8, maven, docker and docker-compose
- setup with the following steps:
(1) Clone all the source code to your local computer with git.
(2) Move all directory whose name is start with "ts-" to your server's other directory.
(3) Move pom.xml and docker-compose.xml to your server to the same directory with "ts-..." directories.
(4) Add the "myproject" directory to your maven ".m2" directory.
The directory index is like /root/.m2/repository/myproject.
(5) Open the terminal and enter the directory where pom.xml loacted.
(6) Use the instruction: mvn clean package And waiting for build success.
(7) Use the instruction: docker-compose build And waiting for build success.
(8) Use the instruction: docker-compose up And wating for all services startup
- before access, you can use "docker ps" to see which port you should access:
on default. the port is 80
than you can use the ip of your server to access it.
Unless something unexpected, if you can see the main interface like below, congratulations!
(1) While access the main interface, Input the start city ,destination city, date and train type , And then click "search" button,
you will get the tickets list , which is like the picture above.
(2) After select trip and seat type, Click "Booking" button, then it will show login dialog( or you can login before)
Just follow that step to login
(3) After login succeed, it will continue with the previous step, in this step, you must choose or add one Contacts,
And decide whether you need Assurance ,food , or consign, than you can click "Select" button.
(4) After select,it will pop up a dialog for you to check whether the order information is correct, if so, then you can
click "submit" button to submit you reservation
(5) The last step is to go to the Order List to find the ticket you reserver before, and click the "Pay" button,
waitting for success, than the buy ticket flow is over.
(6)Also you can modify you order information
(7) If you want search by different conditions such as quickest, cheapest and so on, you can use advanced search function
- The admin panel is used to manage orders, trips, users, prices and so on.
you can use your ip + /adminlogin.html to access the admin panel in broswer
(1) The login panel looks like this, you can use adminroot/adminroot to login (2) The admin's order list panel (3) The admin's travel list panel
- Please download "webdriver.chrome.driver". Modify its file path and "baseUrl". As the picture below. The you can run this test case. You may also change some input parameters in test case as you like.
build:
mvn clean package
docker-compose build
docker-compose up
docker swarm init --advertise-addr 10.141.211.161
docker swarm join-token manager
docker swarm join-token worker
app tag:
docker tag ts/ts-ui-dashboard 10.141.212.25:5555/cluster-ts-ui-dashboard
app local registry:
docker push 10.141.212.25:5555/cluster-ts-ui-dashboard
deploy app (docker swarm):
docker stack deploy --compose-file=docker-compose-swarm.yml my-compose-swarm
monitoring:
docker run -d -p 9000:9000 --name=portainer-ui-local -v /var/run/docker.sock:/var/run/docker.sock portainer/portainer
- You can check the fault replication details on following branches of this git repository
F1 ts-error-process-seq
F2 ts-error-reportui
F3 ts-error-docker-JVM
F4 ts-error-ssl
F5 ts-error-cross-timeout-status(chance)
F7 ts-external-normal
F8 ts-error-redis
F10 ts-error-normal
F11 ts-error-bomupdate
F12 ts-error-processes-seq-status(chance)
F13 ts-error-queue