(我修改mysql映射目錄及獲取遠程ip的方法)

主要步驟:

搭建簡單的springboot應用

做一個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 方法略
}

Repository 層代碼參考jpa 相關內容。

本地數據庫打開,密碼是上面配置中的,使用mvn spring-boot:run運行起來之后,可以看到ip的次數,每次統計后就自增。

dockercompose配置文件

新建docker-compose.yaml文件,如下:

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所在的目錄。
volumes 指定了本地目錄下的文件與容器目標地址的映射。
environment 配置了容器所需要的環境變量
ports 配置了本地與容器的映射的端口,本地端口在前,容器端口在后

ngixn下的volumes配置的作用:把我們寫好的nginx配置文件直接覆蓋到容器中默認的nginx配置文件。

mysql下的volumes配置的作用:把mysql的數據文件映射到了本地mysqldata目錄下。當容器刪除后,數據還在。

app下的volumes配置的作用:第一行是把代碼文件映射到容器中。第二行是把maven的倉庫文件映射到本地。容器刪除之后,再構建,不用重新下載依賴包。

command: mvn clean spring-boot:run -Dspring-boot.run.profiles=docker

命令是編譯運行容器中的項目,使用docker的profiles。

所以我們要添加的文件

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來運行。

贊(4)
聲明:本網站發布的內容(圖片、視頻和文字)以原創、轉載和分享網絡內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。郵箱:3140448839@qq.com。本站原創內容未經允許不得轉載,或轉載時需注明出處:三五互聯知識庫 » dockercompose搭建springboot-mysql-nginx應用

登錄

找回密碼

注冊

主站蜘蛛池模板: 国产盗摄视频一区二区三区| 九九久久人妻精品一区色| 九九热在线观看精品视频| 亚洲第一极品精品无码久久| 国产线播放免费人成视频播放| 小污女小欲女导航| 日韩精品中文女同在线播放| 邹平县| 国产AV无码专区亚洲AWWW| 99久久精品国产免费看| 91色老久久精品偷偷蜜臀| 大香伊蕉在人线国产最新2005| 亚洲av成人精品日韩一区| 国产成人a在线观看视频免费| 欧洲中文字幕一区二区| 国产一区精品在线免费看| www夜插内射视频网站| 亚洲成片在线看一区二区| 99久久精品国产一区二区蜜芽| 亚洲人成小说网站色在线 | 久久国产精品精品国产色| 久久国产成人高清精品亚洲| 五月婷婷开心中文字幕| 成人免费乱码大片a毛片| 亚欧成人精品一区二区乱| 国产色无码专区在线观看| 亚洲中文字幕aⅴ天堂| 色欲AV无码一区二区人妻| 欧美乱妇狂野欧美在线视频| 丰满少妇内射一区| 欧美乱大交aaaa片if| 亚洲AV日韩AV高清在线观看| 久久人人爽爽人人爽人人片av| 亚洲精品无码久久千人斩| 欧美日韩中文字幕久久伊人| 在线人成免费视频69国产| 少妇性bbb搡bbb爽爽爽欧美| 99视频精品全部免费 在线| 久久99精品国产99久久6尤物| 久久精品噜噜噜成人av| 二区三区亚洲精品国产|