자바 Idea 원 격 원 격 단 추 를 통 해 springboot 를 Docker 에 배치 합 니 다.
1.Docker 설치 참고https://docs.docker.com/install/
2.docker 원 격 연결 포트 설정
vi /usr/lib/systemd/system/docker.service
ExecStart 를 찾 아 맨 뒤에-H 를 추가 합 니 다.tcp://0.0.0.0:2375다음 그림 과 같다.3.docker 다시 시작
systemctl daemon-reload
systemctl start docker
4.포트 열기firewall-cmd --zone=public --add-port=2375/tcp --permanent
5.Idea 플러그 인 설치,재 부팅6.원 격 docker 연결
(1)설정 편집
(2)원 격 docker 주소 입력
(3)연결 에 성공 하면 원 격 docker 용기 와 미 러 가 표 시 됩 니 다.
2.새 항목
1.springboot 프로젝트 만 들 기
프로젝트 구성 도
(1)pom 파일 설정
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>docker-demo</groupId>
<artifactId>com.demo</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.2.RELEASE</version>
<relativePath />
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<docker.image.prefix>com.demo</docker.image.prefix>
<java.version>1.8</java.version>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.0.0</version>
<configuration>
<dockerDirectory>src/main/docker</dockerDirectory>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
<plugin>
<artifactId>maven-antrun-plugin</artifactId>
<executions>
<execution>
<phase>package</phase>
<configuration>
<tasks>
<copy todir="src/main/docker" file="target/${project.artifactId}-${project.version}.${project.packaging}"></copy>
</tasks>
</configuration>
<goals>
<goal>run</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
</dependencies>
</project>
(2)src/main 디 렉 터 리 에 docker 디 렉 터 리 를 만 들 고 Dockerfile 파일 을 만 듭 니 다.
FROM openjdk:8-jdk-alpine
ADD *.jar app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
(3)resource 디 렉 터 리 에 application.properties 파일 만 들 기
logging.config=classpath:logback.xml
logging.path=/home/developer/app/logs/
server.port=8990
(4)DockerApplication 파일 만 들 기
@SpringBootApplication
public class DockerApplication {
public static void main(String[] args) {
SpringApplication.run(DockerApplication.class, args);
}
}
(5)DockerController 파일 만 들 기
@RestController
public class DockerController {
static Log log = LogFactory.getLog(DockerController.class);
@RequestMapping("/")
public String index() {
log.info("Hello Docker!");
return "Hello Docker!";
}
}
(6)설정 추가명령 해석
(8)실행
먼저 pull 기본 미 러 를 만 든 다음 미 러 를 포장 하고 미 러 를 원 격 docker 에 배치 하여 실행 합 니 다.
여기 서 미 러 이름 은 docker-demo:1.1 이 고 docker 용 기 는 docker-server 입 니 다.
(9)실행 성공
(10)브 라 우 저 접근
(11)로그 보기
이로써 아이디어 배 치 를 통 해 springboot 프로젝트 를 docker 에 성공 하 였 습 니 다!자바 웹 프로젝트 를 배치 하 는 것 이 이렇게 간단 하고 편리 하 다 는 것 은 상상 하기 어렵다!
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Is Eclipse IDE dying?In 2014 the Eclipse IDE is the leading development environment for Java with a market share of approximately 65%. but ac...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.