使用docker建置spring-boot應用,是把編譯好的jar包建置到映像中。
這篇是把spring-boot連同資料庫,做為一組docker服務運作起來。
這裡只是把自己操作記錄下來,完整運行的程式碼請參考「參考」中的引用1中的內容。
(我修改mysql映射目錄及取得遠端ip的方法)
主要步驟:
建置簡單的springboot應用程式
編寫dockercompose設定檔
做一個web應用,統計訪問該網站的ip次數。
並儲存到mysql資料庫中,這裡使用jpa的方式存取資料庫。 依賴<parent>
<groupid>org.springframework.boot</groupid>
<artifactid>spring-boot-starter-parent</artifactid>
<version>2.0.0.release</version>
</parent>
web,jpa,mysql,tset庫的依賴
<dependencies> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-data-jpa</artifactid> </dependency> <dependency> <groupid>mysql</groupid> <artifactid>mysql-connector-java</artifactid> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-test</artifactid> <scope>test</scope> </dependency> </dependencies>設定檔
spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.driver spring.jpa.properties.hibernate.hbm2ddl.auto=update spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.mysql5innodbdialect spring.jpa.show-sql=true
核心程式碼
@restcontroller public class visitorcontroller{ @autowired private visitorrepository repository; @requestmapping("/") public string index(httpservletrequest request) { string ip= request.getheader("x-real-ip"); if(ip== null || "".equals(ip)) { ip = request.getremoteaddr(); } visitor visitor = repository.findbyip(ip); if(visitor == null) { visitor = new visitor(); visitor.setip(ip); visitor.settimes(1l); } else { visitor.settimes(visitor.gettimes()+1); } repository.save(visitor); return "ip:"+visitor.getip()+" "+visitor.gettimes()+" times."; } }
@entity public class visitor { @id @generatedvalue private long id; @column(nullable=false) private long times; @column(nullable=false) private string ip; // get,set 方法略 }
dockercompose設定檔
version: '3' services: nginx: container_name: v-nginx image: nginx:1.13 restart: always ports: - 80:80 - 443:443 volumes: - ./nginx/conf.d:/etc/nginx/conf.d mysql: container_name: v-mysql image: mysql/mysql-server:5.7 environment: mysql_database: test mysql_root_password: root mysql_root_host: '%' ports: - "3306:3306" volumes: - ./mysqldata:/var/lib/mysql restart: always app: restart: always build: ./app working_dir: /app volumes: - ./app:/app - ~/.m2:/root/.m2 expose: - "8080" depends_on: - nginx - mysql command: mvn clean spring-boot:run -dspring-boot.run.profiles=docker主要對這個設定檔進行解釋,並在檔案系統中增加相關的配置。
services下面有三個服務nginx,mysql,app。
images 指明使用鏡像。 nginx及mysql都是直接取docker倉庫中已有的。
app中沒有指明映像,但用build指定了dockerfile所在的目錄。
environment 配置了容器所需要的環境變數
ports 配置了本地與容器的映射的端口,本地端口在前,容器端口在後ngixn下的volumes配置的作用:把我們寫好的nginx設定檔直接覆蓋到容器中預設的nginx設定檔。mysql下的volumes配置的作用:把mysql的資料檔映射到了本機mysqldata目錄下。當容器刪除後,資料還在。
所以我們要新增的文件
server { listen 80; charset utf-8; access_log off; location / { proxy_pass http://app:8080; proxy_set_header host $host:$server_port; proxy_set_header x-forwarded-host $server_name; proxy_set_header x-real-ip $remote_addr; proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for; } location /static { access_log off; expires 30d; alias /app/static; } }######部署驗證############把整體的文件拷貝到伺服器上,使用###docker-compose up###來運作。 ###
以上是怎麼使用dockercompose搭建springboot-mysql-nginx應用的詳細內容。更多資訊請關注PHP中文網其他相關文章!