Skip to content

Commit c1a32c7

Browse files
feat(spring-databases-example): first commit
1 parent 09a53c5 commit c1a32c7

File tree

27 files changed

+1671
-0
lines changed

27 files changed

+1671
-0
lines changed
Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
name: spring-databases-example CI Build
2+
3+
on:
4+
pull_request:
5+
branches: [master]
6+
paths:
7+
- "spring-databases-example/**"
8+
types:
9+
- opened
10+
- synchronize
11+
- reopened
12+
13+
jobs:
14+
15+
integration-tests:
16+
name: Run Unit & Integration Tests
17+
runs-on: ubuntu-latest
18+
defaults:
19+
run:
20+
working-directory: spring-databases-example
21+
strategy:
22+
matrix:
23+
distribution: [ 'temurin' ]
24+
java: [ '21' ]
25+
steps:
26+
- uses: actions/checkout@v5
27+
with:
28+
fetch-depth: 0
29+
30+
- name: Set up JDK ${{ matrix.java }}
31+
uses: actions/[email protected]
32+
with:
33+
java-version: ${{ matrix.java }}
34+
distribution: ${{ matrix.distribution }}
35+
cache: 'maven'
36+
- name: Build and analyze
37+
run: ./mvnw clean verify

pom.xml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@
1818
<module>spring-jasper-example</module>
1919
<module>spring-oracle-example</module>
2020
<module>spring-multimodule-example</module>
21+
<module>spring-databases-example</module>
2122
</modules>
2223

2324
</project>
Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
# Include any files or directories that you don't want to be copied to your
2+
# container here (e.g., local build artifacts, temporary files, etc.).
3+
#
4+
# For more help, visit the .dockerignore file reference guide at
5+
# https://docs.docker.com/go/build-context-dockerignore/
6+
7+
**/.DS_Store
8+
**/.classpath
9+
**/.dockerignore
10+
**/.env
11+
**/.factorypath
12+
**/.git
13+
**/.gitignore
14+
**/.idea
15+
**/.project
16+
**/.sts4-cache
17+
**/.settings
18+
**/.toolstarget
19+
**/.vs
20+
**/.vscode
21+
**/.next
22+
**/.cache
23+
**/*.dbmdl
24+
**/*.jfm
25+
**/charts
26+
**/docker-compose*
27+
**/compose.y*ml
28+
**/Dockerfile*
29+
**/secrets.dev.yaml
30+
**/values.dev.yaml
31+
**/vendor
32+
LICENSE
33+
README.md
34+
**/*.class
35+
**/*.iml
36+
**/*.ipr
37+
**/*.iws
38+
**/*.log
39+
**/.apt_generated
40+
**/.gradle
41+
**/.gradletasknamecache
42+
**/.nb-gradle
43+
**/.springBeans
44+
**/build
45+
**/dist
46+
**/gradle-app.setting
47+
**/nbbuild
48+
**/nbdist
49+
**/nbproject/private
50+
**/target
51+
*.ctxt
52+
.mtj.tmp
53+
.mvn/timing.properties
54+
buildNumber.properties
55+
dependency-reduced-pom.xml
56+
hs_err_pid*
57+
pom.xml.next
58+
pom.xml.releaseBackup
59+
pom.xml.tag
60+
pom.xml.versionsBackup
61+
release.properties
62+
replay_pid*
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
wrapperVersion=3.3.4
2+
distributionType=only-script
3+
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.9/apache-maven-3.9.9-bin.zip
Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
1+
FROM eclipse-temurin:21-jdk-jammy as deps
2+
3+
WORKDIR /build
4+
5+
COPY --chmod=0755 mvnw mvnw
6+
COPY .mvn/ .mvn/
7+
8+
RUN --mount=type=bind,source=pom.xml,target=pom.xml \
9+
--mount=type=cache,target=/root/.m2 ./mvnw dependency:go-offline -DskipTests
10+
11+
FROM deps as package
12+
13+
WORKDIR /build
14+
15+
COPY ./src src/
16+
RUN --mount=type=bind,source=pom.xml,target=pom.xml \
17+
--mount=type=cache,target=/root/.m2 \
18+
./mvnw package -DskipTests && \
19+
mv target/$(./mvnw help:evaluate -Dexpression=project.artifactId -q -DforceStdout)-$(./mvnw help:evaluate -Dexpression=project.version -q -DforceStdout).jar target/app.jar
20+
21+
FROM package as extract
22+
23+
WORKDIR /build
24+
25+
RUN java -Djarmode=layertools -jar target/app.jar extract --destination target/extracted
26+
27+
FROM eclipse-temurin:21-jre-jammy AS final
28+
29+
ARG UID=10001
30+
RUN adduser \
31+
--disabled-password \
32+
--gecos "" \
33+
--home "/nonexistent" \
34+
--shell "/sbin/nologin" \
35+
--no-create-home \
36+
--uid "${UID}" \
37+
appuser
38+
USER appuser
39+
40+
COPY --from=extract build/target/extracted/dependencies/ ./
41+
COPY --from=extract build/target/extracted/spring-boot-loader/ ./
42+
COPY --from=extract build/target/extracted/snapshot-dependencies/ ./
43+
COPY --from=extract build/target/extracted/application/ ./
44+
45+
EXPOSE 8080
46+
47+
ENTRYPOINT [ "java", "org.springframework.boot.loader.launch.JarLauncher" ]
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
2+
services:
3+
4+
app-mysql:
5+
container_name: app-mysql
6+
build:
7+
context: .
8+
ports:
9+
- "8080:8080"
10+
environment:
11+
SPRING_DATASOURCE_URL: jdbc:mysql://mysql-container:3306/myapp_db?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC
12+
SPRING_DATASOURCE_USERNAME: myapp_user
13+
SPRING_DATASOURCE_PASSWORD: user123
14+
SPRING_DATASOURCE_DRIVER: com.mysql.cj.jdbc.Driver
15+
SPRING_JPA_HIBERNATE_DDL_AUTO: none
16+
SPRING_JPA_SHOW_SQL: false
17+
18+
mysql:
19+
image: mysql:8.1
20+
container_name: mysql-container
21+
ports:
22+
- "3306:3306"
23+
environment:
24+
MYSQL_ROOT_PASSWORD: root123
25+
MYSQL_DATABASE: myapp_db
26+
MYSQL_USER: myapp_user
27+
MYSQL_PASSWORD: user123

0 commit comments

Comments
 (0)