Skip to content

Commit 91764cc

Browse files
committed
docker and open api is added
1 parent ce2f751 commit 91764cc

File tree

49 files changed

+1721
-0
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

49 files changed

+1721
-0
lines changed

.mvn/wrapper/maven-wrapper.jar

57.4 KB
Binary file not shown.
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.4/apache-maven-3.8.4-bin.zip
2+
wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar

api/.gitignore

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
HELP.md
2+
target/
3+
!.mvn/wrapper/maven-wrapper.jar
4+
!**/src/main/**/target/
5+
!**/src/test/**/target/
6+
7+
### STS ###
8+
.apt_generated
9+
.classpath
10+
.factorypath
11+
.project
12+
.settings
13+
.springBeans
14+
.sts4-cache
15+
16+
### IntelliJ IDEA ###
17+
.idea
18+
*.iws
19+
*.iml
20+
*.ipr
21+
22+
### NetBeans ###
23+
/nbproject/private/
24+
/nbbuild/
25+
/dist/
26+
/nbdist/
27+
/.nb-gradle/
28+
build/
29+
!**/src/main/**/build/
30+
!**/src/test/**/build/
31+
32+
### VS Code ###
33+
.vscode/

api/pom.xml

Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
3+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
4+
<modelVersion>4.0.0</modelVersion>
5+
<parent>
6+
<groupId>org.springframework.boot</groupId>
7+
<artifactId>spring-boot-starter-parent</artifactId>
8+
<version>2.6.6</version>
9+
<relativePath/> <!-- lookup parent from repository -->
10+
</parent>
11+
<groupId>io.javatab.microservices.api</groupId>
12+
<artifactId>api</artifactId>
13+
<version>1.0.0</version>
14+
<name>api</name>
15+
<description>Demo project for Spring Boot</description>
16+
<properties>
17+
<java.version>17</java.version>
18+
</properties>
19+
<dependencies>
20+
<dependency>
21+
<groupId>org.springframework.boot</groupId>
22+
<artifactId>spring-boot-starter-webflux</artifactId>
23+
</dependency>
24+
<dependency>
25+
<groupId>org.springdoc</groupId>
26+
<artifactId>springdoc-openapi-common</artifactId>
27+
<version>1.5.10</version>
28+
</dependency>
29+
<dependency>
30+
<groupId>org.springframework.boot</groupId>
31+
<artifactId>spring-boot-starter-test</artifactId>
32+
<scope>test</scope>
33+
</dependency>
34+
<dependency>
35+
<groupId>io.projectreactor</groupId>
36+
<artifactId>reactor-test</artifactId>
37+
<scope>test</scope>
38+
</dependency>
39+
</dependencies>
40+
41+
<build>
42+
<plugins>
43+
<plugin>
44+
<groupId>org.springframework.boot</groupId>
45+
<artifactId>spring-boot-maven-plugin</artifactId>
46+
<configuration>
47+
<classifier>exec</classifier>
48+
</configuration>
49+
</plugin>
50+
</plugins>
51+
</build>
52+
53+
</project>
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
package io.javatab.microservices.api;
2+
3+
import org.springframework.boot.SpringApplication;
4+
import org.springframework.boot.autoconfigure.SpringBootApplication;
5+
6+
@SpringBootApplication
7+
public class ApiApplication {
8+
9+
public static void main(String[] args) {
10+
SpringApplication.run(ApiApplication.class, args);
11+
}
12+
13+
}
Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,29 @@
11
package io.javatab.microservices.api.composite.course;
22

3+
import io.swagger.v3.oas.annotations.Operation;
4+
import io.swagger.v3.oas.annotations.responses.ApiResponse;
5+
import io.swagger.v3.oas.annotations.responses.ApiResponses;
36
import org.springframework.web.bind.annotation.GetMapping;
47
import org.springframework.web.bind.annotation.PathVariable;
58
import reactor.core.publisher.Mono;
69

710
public interface CourseCompositeService {
811

12+
/**
13+
* Sample usage: "curl $HOST:$PORT/course-composite/1".
14+
*
15+
* @param courseId of the course
16+
* @return the composite course info, if found, else null
17+
*/
18+
@Operation(
19+
summary = "${open-api.course-composite.get-composite-course.description}",
20+
description = "${open-api.course-composite.get-composite-course.notes}")
21+
@ApiResponses(value = {
22+
@ApiResponse(responseCode = "200", description = "${open-api.responseCodes.ok.description}"),
23+
@ApiResponse(responseCode = "400", description = "${open-api.responseCodes.badRequest.description}"),
24+
@ApiResponse(responseCode = "404", description = "${open-api.responseCodes.notFound.description}"),
25+
@ApiResponse(responseCode = "422", description = "${open-api.responseCodes.unprocessableEntity.description}")
26+
})
927
@GetMapping("/course-composite/{courseId}")
1028
Mono<CourseAggregate> getCourse(@PathVariable("courseId") int courseId);
1129
}
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
package io.javatab.microservices.api;
2+
3+
import org.junit.jupiter.api.Test;
4+
import org.springframework.boot.test.context.SpringBootTest;
5+
6+
@SpringBootTest
7+
class ApiApplicationTests {
8+
9+
@Test
10+
void contextLoads() {
11+
}
12+
13+
}

create-project.bash

Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
#!/usr/bin/env bash
2+
3+
mkdir microservices
4+
cd microservices
5+
6+
spring init \
7+
--boot-version=2.5.2 \
8+
--build=maven \
9+
--java-version=17 \
10+
--packaging=jar \
11+
--name=student-service \
12+
--package-name=io.javatab.microservices.core.student \
13+
--groupId=io.javatab.microservices.core.student \
14+
--dependencies=actuator,webflux \
15+
--version=1.0.0 \
16+
student-service
17+
18+
spring init \
19+
--boot-version=2.5.2 \
20+
--build=maven \
21+
--java-version=17 \
22+
--packaging=jar \
23+
--name=course-service \
24+
--package-name=io.javatab.microservices.core.course \
25+
--groupId=io.javatab.microservices.core.course \
26+
--dependencies=actuator,webflux \
27+
--version=1.0.0 \
28+
course-service
29+
30+
spring init \
31+
--boot-version=2.5.2 \
32+
--build=maven \
33+
--java-version=17 \
34+
--packaging=jar \
35+
--name=vote-service \
36+
--package-name=io.javatab.microservices.core.vote \
37+
--groupId=io.javatab.microservices.core.vote \
38+
--dependencies=actuator,webflux \
39+
--version=1.0.0 \
40+
vote-service
41+
42+
spring init \
43+
--boot-version=2.5.2 \
44+
--build=maven \
45+
--java-version=17 \
46+
--packaging=jar \
47+
--name=search-service \
48+
--package-name=io.javatab.microservices.core.search \
49+
--groupId=io.javatab.microservices.core.search \
50+
--dependencies=actuator,webflux \
51+
--version=1.0.0 \
52+
search-service
53+
54+
spring init \
55+
--boot-version=2.5.2 \
56+
--build=maven \
57+
--java-version=17 \
58+
--packaging=jar \
59+
--name=course-composite-service \
60+
--package-name=io.javatab.microservices.composite.course \
61+
--groupId=io.javatab.microservices.composite.course \
62+
--dependencies=actuator,webflux \
63+
--version=1.0.0 \
64+
course-composite-service
65+
66+
cd ..

docker/docker-compose.yml

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
version: '2.1'
2+
3+
services:
4+
course:
5+
build: ../microservices/course-service
6+
image: javatab/course_service:v1
7+
container_name: course_service_v1
8+
mem_limit: 512m
9+
environment:
10+
- SPRING_PROFILES_ACTIVE=docker
11+
12+
search:
13+
build: ../microservices/search-service
14+
image: javatab/search_service:v1
15+
container_name: search_service_v1
16+
mem_limit: 512m
17+
environment:
18+
- SPRING_PROFILES_ACTIVE=docker
19+
20+
student:
21+
build: ../microservices/student-service
22+
image: javatab/student_service:v1
23+
container_name: student_service_v1
24+
mem_limit: 512m
25+
environment:
26+
- SPRING_PROFILES_ACTIVE=docker
27+
28+
vote:
29+
build: ../microservices/vote-service
30+
image: javatab/vote_service:v1
31+
container_name: vote_service_v1
32+
mem_limit: 512m
33+
environment:
34+
- SPRING_PROFILES_ACTIVE=docker
35+
36+
course-composite:
37+
build: ../microservices/course-composite-service
38+
image: javatab/course_composite_service:v1
39+
container_name: course_composite_service_v1
40+
mem_limit: 512m
41+
ports:
42+
- "8080:8080" # Only this service will be exposed to outside containers so no port binding for above images
43+
environment:
44+
- SPRING_PROFILES_ACTIVE=docker

0 commit comments

Comments
 (0)