{"id":39836,"date":"2024-01-06T08:14:59","date_gmt":"2023-08-31T04:37:40","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/"},"modified":"2024-05-04T17:08:37","modified_gmt":"2024-05-04T09:08:37","slug":"%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/","title":{"rendered":"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7"},"content":{"rendered":"<h1>\u4f7f\u7528Spring Boot\u8f93\u51fa\u65e5\u5fd7\u7684\u65b9\u6cd5<\/h1>\n<h2>\u89e3\u91ca\u7684\u76ee\u7684\u662f\u4ec0\u4e48\uff1f<\/h2>\n<p>\u5b66\u4e60\u5e76\u6df1\u5165\u7406\u89e3\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7\u7684\u6b65\u9aa4\u3002<\/p>\n<h2>\u5b9e\u73b0<\/h2>\n<p>\u5c06\u65e5\u5fd7\u8f93\u51fa\u914d\u7f6e\u96c6\u6210\u5230\u672c\u5730\u73af\u5883\u7684Spring Boot\u5e94\u7528\u4e2d\uff0c\u5e76\u5c06\u65e5\u5fd7\u540c\u65f6\u8f93\u51fa\u5230\u6807\u51c6\u8f93\u51fa\u548c\u6587\u4ef6\u4e2d\u3002\u4f7f\u7528Logback\u4f5c\u4e3a\u7528\u4e8e\u8f93\u51fa\u65e5\u5fd7\u7684SLF4J\u5b9e\u73b0\u5e93\u3002<\/p>\n<h2>\u6280\u672f\u80cc\u666f (j\u00ec sh\u00f9<\/h2>\n<p>SLF4J\uff08Simple Logging Facade for Java\uff09\u662f\u4ec0\u4e48\uff1f<\/p>\n<details>\u60a8\u53ef\u4ee5\u5c55\u5f00\u67e5\u770b\u3002Java\u5e94\u7528\u7a0b\u5e8f\u7684\u65e5\u5fd7\u8bb0\u5f55<br \/>\nSLF4J\uff08Simple Logging Facade for Java\uff09\u662f\u4e00\u79cd\u7528\u4e8eJava\u5e94\u7528\u7a0b\u5e8f\u7684\u5f00\u6e90\u65e5\u5fd7\u8bb0\u5f55\u6846\u67b6\u3002SLF4J\u5c06\u4e0eJava\u65e5\u5fd7\u8bb0\u5f55\u76f8\u5173\u7684API\u62bd\u8c61\u5316\uff0c\u4f7f\u5f97\u53ef\u4ee5\u4ee5\u4e0d\u4f9d\u8d56\u4e8e\u4efb\u4f55\u7279\u5b9a\u65e5\u5fd7\u8bb0\u5f55\u6846\u67b6\u7684\u65b9\u5f0f\u7f16\u5199\u5e94\u7528\u7a0b\u5e8f\u4ee3\u7801\u3002\u6362\u53e5\u8bdd\u8bf4\uff0c\u5e94\u7528\u7a0b\u5e8f\u53ef\u4ee5\u5728\u4e0d\u4f9d\u8d56\u4e8e\u591a\u4e2a\u65e5\u5fd7\u8bb0\u5f55\u6846\u67b6\u7684\u60c5\u51b5\u4e0b\u4f7f\u7528\u65e5\u5fd7\u8bb0\u5f55\u529f\u80fd\u3002<br \/>\nLogback\u662fSLF4J API\u7684\u4e00\u4e2a\u5b9e\u73b0\u540e\u7aef\u4e4b\u4e00\u3002\u4e5f\u5c31\u662f\u8bf4\uff0c\u53ef\u4ee5\u5728\u4f7f\u7528SLF4J API\u8f93\u51fa\u65e5\u5fd7\u7684\u5e94\u7528\u7a0b\u5e8f\u4e2d\u4f7f\u7528Logback\u4f5c\u4e3a\u540e\u7aef\u3002Logback\u662f\u4e00\u4e2a\u5feb\u901f\u800c\u7075\u6d3b\uff0c\u63d0\u4f9b\u8bb8\u591a\u529f\u80fd\u7684\u65e5\u5fd7\u8bb0\u5f55\u6846\u67b6\uff0c\u7ed3\u5408SLF4J\u4f7f\u7528\u53ef\u4ee5\u4fdd\u6301\u4e00\u81f4\u6027\u7684\u65e5\u5fd7\u8bb0\u5f55\u3002<br \/>\n\u56e0\u6b64\uff0cSLF4J\u548cLogback\u901a\u5e38\u4e00\u8d77\u4f7f\u7528\u6765\u6539\u5584\u5e94\u7528\u7a0b\u5e8f\u7684\u65e5\u5fd7\u8bb0\u5f55\u529f\u80fd\uff0c\u5e76\u4e14\u901a\u8fc7\u7ec4\u5408\u4f7f\u7528\uff0c\u53ef\u4ee5\u63d0\u4f9b\u7075\u6d3b\u6027\uff0c\u6027\u80fd\u4ee5\u53ca\u4e00\u81f4\u6027\u7684\u65e5\u5fd7\u8f93\u51fa\u3002<\/p>\n<\/details>\n<h2>\u8f6f\u4ef6\u5f00\u53d1\u73af\u5883<\/h2>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Windows 11 Home 22H2 \u3092\u4f7f\u7528\u3057\u3066\u3044\u307e\u3059\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>WSL \u306e Ubuntu \u3092\u64cd\u4f5c\u3057\u3066\u3044\u304d\u307e\u3059\u306e\u3067 macOS \u306e\u65b9\u3082\u53c2\u8003\u306b\u3057\u3066\u9802\u3051\u307e\u3059\u3002<\/p>\n<details>WSL\uff08Microsoft Store\u5e94\u7528\u7248\uff09<br \/>\n&gt; wsl &#8211;version<br \/>\nWSL\u7248\u672c\uff1a1.0.3.0<br \/>\n\u5185\u6838\u7248\u672c\uff1a5.15.79.1<br \/>\nWSLg\u7248\u672c\uff1a1.0.47Ubuntu<br \/>\n$ lsb_release -a<br \/>\n\u6ca1\u6709\u53ef\u7528\u7684LSB\u6a21\u5757\u3002<br \/>\n\u53d1\u884c\u5546ID\uff1aUbuntu<br \/>\n\u63cf\u8ff0\uff1aUbuntu 22.04.1 LTS<br \/>\n\u7248\u672c\uff1a22.04<\/p>\n<p>Java JDK \u203b \u6700\u5c0f\u914d\u7f6eJava JDK\u7684\u5b89\u88c5\u548cHello World\uff01<br \/>\n$ java -version<br \/>\nopenjdk\u7248\u672c&#8221;11.0.17&#8243; 2022-10-18<br \/>\nOpenJDK\u8fd0\u884c\u65f6\u73af\u5883\uff08\u6784\u5efa11.0.17+8-post-Ubuntu-1ubuntu222.04\uff09<br \/>\nOpenJDK 64\u4f4d\u670d\u52a1\u5668VM\uff08\u6784\u5efa11.0.17+8-post-Ubuntu-1ubuntu222.04\uff0c\u6df7\u5408\u6a21\u5f0f\uff0c\u5171\u4eab\uff09<\/p>\n<p>Maven \u203b \u6700\u5c0f\u914d\u7f6eMaven\u7684\u5b89\u88c5\u548cHello World\uff01<br \/>\n$ mvn -version<br \/>\nApache Maven 3.6.3<br \/>\nMaven\u4e3b\u76ee\u5f55\uff1a\/usr\/share\/maven<br \/>\nJava\u7248\u672c\uff1a11.0.17\uff0c\u4f9b\u5e94\u5546\uff1aUbuntu\uff0c\u8fd0\u884c\u65f6\uff1a\/usr\/lib\/jvm\/java-11-openjdk-amd64<\/p>\n<\/details>\n<p>\u5728\u8fd9\u7bc7\u6587\u7ae0\u4e2d\uff0c\u6211\u4eec\u4e3b\u8981\u4f7f\u7528Ubuntu\u7ec8\u7aef\u8fdb\u884c\u64cd\u4f5c\u3002<\/p>\n<h2>\u8f93\u51fa\u65e5\u5fd7\u7684\u6b65\u9aa4 de<\/h2>\n<h3>\u521b\u5efa\u4e00\u4e2a\u6700\u5c0f\u9650\u7684Spring Boot\u5e94\u7528\u7a0b\u5e8f\u3002<\/h3>\n<details>\u8fd9\u91cc\u5c55\u793a\u7ed9\u4f60\u770b\u3002\u521b\u5efa\u9879\u76ee\u6587\u4ef6\u5939<br \/>\n$ cd ~<br \/>\n$ mkdir -p tmp\/hello-spring-log<br \/>\n$ cd ~\/tmp\/hello-spring-log<\/p>\n<p>\u203b \u5c06~\/tmp\/hello-spring-log\u4f5c\u4e3a\u9879\u76ee\u6587\u4ef6\u5939\u3002<\/p>\n<p>\u521b\u5efa\u5e94\u7528\u7a0b\u5e8f\u7c7b<br \/>\n\u203b \u4e3a\u4e86\u7b80\u5316\u914d\u7f6e\uff0c\u5199\u51fa\u4e86\u6240\u6709\u5143\u7d20\u3002<br \/>\n$ mkdir -p src\/main\/java\/com\/example\/spring<br \/>\n$ vim src\/main\/java\/com\/example\/spring\/SpringbootApplication.java<\/p>\n<p>\u6587\u4ef6\u5185\u5bb9<\/p>\n<p>SpringbootApplication.java<br \/>\npackage com.example.spring;<\/p>\n<p>import org.springframework.boot.SpringApplication;<br \/>\nimport org.springframework.boot.autoconfigure.SpringBootApplication;<br \/>\nimport org.springframework.web.bind.annotation.GetMapping;<br \/>\nimport org.springframework.web.bind.annotation.RestController;<\/p>\n<p>@RestController<br \/>\n@SpringBootApplication<br \/>\npublic class SpringbootApplication {<\/p>\n<p>public static void main(String[] args) {<br \/>\nSpringApplication.run(SpringbootApplication.class, args);<br \/>\n}<\/p>\n<p>@GetMapping(&#8220;\/hello&#8221;)<br \/>\npublic String hello() {<br \/>\nreturn &#8220;Hello World!&#8221;;<br \/>\n}<br \/>\n}<\/p>\n<p>\u521b\u5efapom.xml<br \/>\n$ vim pom.xml<\/p>\n<p>\u6587\u4ef6\u5185\u5bb9<\/p>\n<p>pom.xml<br \/>\n<!--?xml version=\"1.0\" encoding=\"UTF-8\"?--><br \/>\n4.0.0<br \/>\norg.springframework.boot<br \/>\nspring-boot-starter-parent<br \/>\n2.7.8<br \/>\n<!-- lookup parent from repository --><br \/>\ncom.example<br \/>\nhello-spring-log<br \/>\n1.0<br \/>\nhello-spring-log<\/p>\n<p>11<br \/>\nUTF-8<\/p>\n<p>org.springframework.boot<br \/>\nspring-boot-starter-web<\/p>\n<p>app<br \/>\norg.springframework.boot<br \/>\nspring-boot-maven-plugin<\/p>\n<p>\u8fd0\u884cSpring Boot\u5e94\u7528<br \/>\n\u6784\u5efaJava\u5e94\u7528<br \/>\n$ mvn clean install<\/p>\n<p>\u542f\u52a8Java\u5e94\u7528\uff08\u4f7f\u7528Ctrl + C\u505c\u6b62\uff09<br \/>\n$ mvn spring-boot:run<\/p>\n<p>\u901a\u8fc7\u53e6\u4e00\u4e2a\u7ec8\u7aef\u7a97\u53e3\u4f7f\u7528\u547d\u4ee4\u8fdb\u884c\u786e\u8ba4<br \/>\n$ curl http:\/\/localhost:8080\/hello<br \/>\nHello World!<\/p>\n<p>\u4eceSpring Boot\u5e94\u7528\u4e2d\u83b7\u53d6\u5230\u4e86&#8221;Hello World!&#8221;\u3002<\/p>\n<\/details>\n<h3>\u6dfb\u52a0\u5904\u7406\u65e5\u5fd7\u7684\u5e93<\/h3>\n<p>\u6211\u5c06\u7f16\u8f91pom.xml\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>vim pom.xml\r\n<\/code><\/pre>\n<p>\u6587\u4ef6\u7684\u5185\u5bb9<\/p>\n<pre class=\"post-pre\"><code><span class=\"cp\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;<\/span>\r\n<span class=\"nt\">&lt;project<\/span> <span class=\"na\">xmlns=<\/span><span class=\"s\">\"http:\/\/maven.apache.org\/POM\/4.0.0\"<\/span>\r\n    <span class=\"na\">xmlns:xsi=<\/span><span class=\"s\">\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\"<\/span>\r\n    <span class=\"na\">xsi:schemaLocation=<\/span><span class=\"s\">\"http:\/\/maven.apache.org\/POM\/4.0.0 https:\/\/maven.apache.org\/xsd\/maven-4.0.0.xsd\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;modelVersion&gt;<\/span>4.0.0<span class=\"nt\">&lt;\/modelVersion&gt;<\/span>\r\n    <span class=\"nt\">&lt;parent&gt;<\/span>\r\n        <span class=\"nt\">&lt;groupId&gt;<\/span>org.springframework.boot<span class=\"nt\">&lt;\/groupId&gt;<\/span>\r\n        <span class=\"nt\">&lt;artifactId&gt;<\/span>spring-boot-starter-parent<span class=\"nt\">&lt;\/artifactId&gt;<\/span>\r\n        <span class=\"nt\">&lt;version&gt;<\/span>2.7.8<span class=\"nt\">&lt;\/version&gt;<\/span>\r\n        <span class=\"nt\">&lt;relativePath\/&gt;<\/span> <span class=\"c\">&lt;!-- lookup parent from repository --&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/parent&gt;<\/span>\r\n    <span class=\"nt\">&lt;groupId&gt;<\/span>com.example<span class=\"nt\">&lt;\/groupId&gt;<\/span>\r\n    <span class=\"nt\">&lt;artifactId&gt;<\/span>hello-spring-log<span class=\"nt\">&lt;\/artifactId&gt;<\/span>\r\n    <span class=\"nt\">&lt;version&gt;<\/span>1.0<span class=\"nt\">&lt;\/version&gt;<\/span>\r\n    <span class=\"nt\">&lt;name&gt;<\/span>hello-spring-log<span class=\"nt\">&lt;\/name&gt;<\/span>\r\n\r\n    <span class=\"nt\">&lt;properties&gt;<\/span>\r\n        <span class=\"nt\">&lt;java.version&gt;<\/span>11<span class=\"nt\">&lt;\/java.version&gt;<\/span>\r\n        <span class=\"nt\">&lt;project.build.sourceEncoding&gt;<\/span>UTF-8<span class=\"nt\">&lt;\/project.build.sourceEncoding&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/properties&gt;<\/span>\r\n\r\n    <span class=\"nt\">&lt;dependencies&gt;<\/span>\r\n        <span class=\"nt\">&lt;dependency&gt;<\/span>\r\n            <span class=\"nt\">&lt;groupId&gt;<\/span>org.springframework.boot<span class=\"nt\">&lt;\/groupId&gt;<\/span>\r\n            <span class=\"nt\">&lt;artifactId&gt;<\/span>spring-boot-starter-web<span class=\"nt\">&lt;\/artifactId&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/dependency&gt;<\/span>\r\n\r\n        <span class=\"c\">&lt;!-- Log --&gt;<\/span>\r\n        <span class=\"nt\">&lt;dependency&gt;<\/span>\r\n            <span class=\"nt\">&lt;groupId&gt;<\/span>ch.qos.logback<span class=\"nt\">&lt;\/groupId&gt;<\/span>\r\n            <span class=\"nt\">&lt;artifactId&gt;<\/span>logback-core<span class=\"nt\">&lt;\/artifactId&gt;<\/span>\r\n            <span class=\"nt\">&lt;version&gt;<\/span>1.2.6<span class=\"nt\">&lt;\/version&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/dependency&gt;<\/span>\r\n        <span class=\"nt\">&lt;dependency&gt;<\/span>\r\n            <span class=\"nt\">&lt;groupId&gt;<\/span>ch.qos.logback<span class=\"nt\">&lt;\/groupId&gt;<\/span>\r\n            <span class=\"nt\">&lt;artifactId&gt;<\/span>logback-classic<span class=\"nt\">&lt;\/artifactId&gt;<\/span>\r\n            <span class=\"nt\">&lt;version&gt;<\/span>1.2.6<span class=\"nt\">&lt;\/version&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/dependency&gt;<\/span>\r\n        <span class=\"nt\">&lt;dependency&gt;<\/span>\r\n            <span class=\"nt\">&lt;groupId&gt;<\/span>org.slf4j<span class=\"nt\">&lt;\/groupId&gt;<\/span>\r\n            <span class=\"nt\">&lt;artifactId&gt;<\/span>slf4j-api<span class=\"nt\">&lt;\/artifactId&gt;<\/span>\r\n            <span class=\"nt\">&lt;version&gt;<\/span>1.7.30<span class=\"nt\">&lt;\/version&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/dependency&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/dependencies&gt;<\/span>\r\n\r\n    <span class=\"nt\">&lt;build&gt;<\/span>\r\n        <span class=\"nt\">&lt;finalName&gt;<\/span>app<span class=\"nt\">&lt;\/finalName&gt;<\/span>\r\n        <span class=\"nt\">&lt;plugins&gt;<\/span>\r\n            <span class=\"nt\">&lt;plugin&gt;<\/span>\r\n                <span class=\"nt\">&lt;groupId&gt;<\/span>org.springframework.boot<span class=\"nt\">&lt;\/groupId&gt;<\/span>\r\n                <span class=\"nt\">&lt;artifactId&gt;<\/span>spring-boot-maven-plugin<span class=\"nt\">&lt;\/artifactId&gt;<\/span>\r\n            <span class=\"nt\">&lt;\/plugin&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/plugins&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/build&gt;<\/span>\r\n<span class=\"nt\">&lt;\/project&gt;<\/span>\r\n<\/code><\/pre>\n<details>*\u8aac\u660e<br \/>\n\u203b\u9078\u629c\u3055\u308c\u305f\u90e8\u5206\u306e\u4e00\u90e8<br \/>\n<!-- \u30ed\u30b0 --><\/p>\n<p>ch.qos.logback<br \/>\nlogback-core<br \/>\n1.2.6<\/p>\n<p>ch.qos.logback<br \/>\nlogback-classic<br \/>\n1.2.6<\/p>\n<p>org.slf4j<br \/>\nslf4j-api<br \/>\n1.7.30<br \/>\n\u5982\u679c\u4f7f\u7528 LogBack\uff0c\u901a\u5e38\u9700\u8981\u5305\u62ec logback-core \u548c logback-classic \u8fd9\u4e24\u4e2a\u4f9d\u8d56\u9879\u3002\u8fd9\u4e9b\u4f9d\u8d56\u5305\u542b\u65e5\u5fd7\u8bb0\u5f55\u529f\u80fd\u548c SLF4J\uff08Java\u7684\u7b80\u5355\u65e5\u5fd7\u95e8\u9762\uff09\u7684\u5b9e\u73b0\u3002\u56e0\u6b64\uff0clogback-classic \u4f9d\u8d56\u4e8e SLF4J\uff0c\u800c logback-core \u5219\u4f9d\u8d56\u4e8e logback-classic\u3002<\/p>\n<\/details>\n<h3>\u521b\u5efaSpring Boot\u914d\u7f6e\u6587\u4ef6<\/h3>\n<pre class=\"post-pre\"><code>$ mkdir -p src\/main\/resources\r\n$ vim src\/main\/resources\/application.properties\r\n<\/code><\/pre>\n<p>\u6587\u4ef6\u7684\u5185\u5bb9 de<\/p>\n<pre class=\"post-pre\"><code>spring.profiles.active<span class=\"o\">=<\/span>develop\r\n<\/code><\/pre>\n<details>\u8bf4\u660e<br \/>\nspring.profiles.active\u662fSpring Boot\u5e94\u7528\u7a0b\u5e8f\u4e2d\u7528\u4e8e\u8bbe\u7f6e\u914d\u7f6e\u6587\u4ef6\u7684\u5c5e\u6027\u4e4b\u4e00\u3002\u8be5\u5c5e\u6027\u7528\u4e8e\u6307\u5b9a\u5728\u5e94\u7528\u7a0b\u5e8f\u542f\u52a8\u65f6\u8981\u6fc0\u6d3b\u7684\u914d\u7f6e\u6587\u4ef6\u3002<br \/>\n\u4f8b\u5982\uff0cdevelop\u914d\u7f6e\u6587\u4ef6\u53ef\u80fd\u5305\u542b\u5728\u5f00\u53d1\u65f6\u975e\u5e38\u6709\u7528\u7684\u529f\u80fd\u548c\u5c06\u65e5\u5fd7\u7ea7\u522b\u8bbe\u7f6e\u4e3aDEBUG\u7684\u914d\u7f6e\u3002\u53e6\u4e00\u65b9\u9762\uff0c\u4e5f\u53ef\u4ee5\u6307\u5b9a\u9002\u7528\u4e8e\u751f\u4ea7\u73af\u5883\u64cd\u4f5c\u7684production\u914d\u7f6e\u6587\u4ef6\u3002(Translation may vary.)<\/p>\n<\/details>\n<h3>\u6dfb\u52a0\u65e5\u5fd7\u8bbe\u7f6e\u6587\u4ef6<\/h3>\n<p>\u5728Spring Boot\u5e94\u7528\u7a0b\u5e8f\u4e2d\uff0c\u9ed8\u8ba4\u4f1a\u81ea\u52a8\u52a0\u8f7d\u4f4d\u4e8esrc\/main\/resources\u76ee\u5f55\u4e0b\u7684logback-spring.xml\u6587\u4ef6\u3002<\/p>\n<p>\u521b\u5efalogback-spring.xml.<\/p>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>vim src\/main\/resources\/logback-spring.xml\r\n<\/code><\/pre>\n<p>\u6587\u4ef6\u7684\u5185\u5bb9<\/p>\n<pre class=\"post-pre\"><code><span class=\"cp\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;<\/span>\r\n<span class=\"nt\">&lt;configuration&gt;<\/span>\r\n\r\n    <span class=\"nt\">&lt;springProfile<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"develop\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;include<\/span> <span class=\"na\">resource=<\/span><span class=\"s\">\"org\/springframework\/boot\/logging\/logback\/defaults.xml\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n        <span class=\"nt\">&lt;include<\/span> <span class=\"na\">resource=<\/span><span class=\"s\">\"org\/springframework\/boot\/logging\/logback\/console-appender.xml\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n\r\n        <span class=\"nt\">&lt;appender<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"STDOUT\"<\/span> <span class=\"na\">class=<\/span><span class=\"s\">\"ch.qos.logback.core.ConsoleAppender\"<\/span><span class=\"nt\">&gt;<\/span>\r\n            <span class=\"nt\">&lt;encoder&gt;<\/span>\r\n                <span class=\"nt\">&lt;pattern&gt;<\/span>[%-5le] %lo{0}.%M:%L - %msg%n<span class=\"nt\">&lt;\/pattern&gt;<\/span>\r\n            <span class=\"nt\">&lt;\/encoder&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/appender&gt;<\/span>\r\n\r\n        <span class=\"nt\">&lt;appender<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"FILE\"<\/span> <span class=\"na\">class=<\/span><span class=\"s\">\"ch.qos.logback.core.rolling.RollingFileAppender\"<\/span><span class=\"nt\">&gt;<\/span>\r\n            <span class=\"nt\">&lt;file&gt;<\/span>.\/log\/app.log<span class=\"nt\">&lt;\/file&gt;<\/span>\r\n            <span class=\"nt\">&lt;append&gt;<\/span>true<span class=\"nt\">&lt;\/append&gt;<\/span>\r\n            <span class=\"nt\">&lt;rollingPolicy<\/span> <span class=\"na\">class=<\/span><span class=\"s\">\"ch.qos.logback.core.rolling.TimeBasedRollingPolicy\"<\/span><span class=\"nt\">&gt;<\/span>\r\n                <span class=\"nt\">&lt;fileNamePattern&gt;<\/span>.\/log\/app.%d{yyyy-MM-dd}_%i.log.gz<span class=\"nt\">&lt;\/fileNamePattern&gt;<\/span>\r\n                <span class=\"nt\">&lt;timeBasedFileNamingAndTriggeringPolicy<\/span>\r\n                    <span class=\"na\">class=<\/span><span class=\"s\">\"ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP\"<\/span><span class=\"nt\">&gt;<\/span>\r\n                    <span class=\"nt\">&lt;maxFileSize&gt;<\/span>5MB<span class=\"nt\">&lt;\/maxFileSize&gt;<\/span>\r\n                <span class=\"nt\">&lt;\/timeBasedFileNamingAndTriggeringPolicy&gt;<\/span>\r\n                <span class=\"nt\">&lt;maxHistory&gt;<\/span>31<span class=\"nt\">&lt;\/maxHistory&gt;<\/span>\r\n                <span class=\"nt\">&lt;cleanHistoryOnStart&gt;<\/span>true<span class=\"nt\">&lt;\/cleanHistoryOnStart&gt;<\/span>\r\n            <span class=\"nt\">&lt;\/rollingPolicy&gt;<\/span>\r\n            <span class=\"nt\">&lt;encoder&gt;<\/span>\r\n                <span class=\"nt\">&lt;pattern&gt;<\/span>%date{yyyy-MM-dd HH:mm:ss.SSS} [%-5le] [%t] %C.%M:%L - %m%n<span class=\"nt\">&lt;\/pattern&gt;<\/span>\r\n            <span class=\"nt\">&lt;\/encoder&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/appender&gt;<\/span>\r\n\r\n        <span class=\"nt\">&lt;logger<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"org.springframework\"<\/span> <span class=\"na\">level=<\/span><span class=\"s\">\"INFO\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n        <span class=\"nt\">&lt;logger<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"com.example\"<\/span> <span class=\"na\">level=<\/span><span class=\"s\">\"DEBUG\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n\r\n        <span class=\"nt\">&lt;root<\/span> <span class=\"na\">level=<\/span><span class=\"s\">\"WARN\"<\/span><span class=\"nt\">&gt;<\/span>\r\n            <span class=\"nt\">&lt;appender-ref<\/span> <span class=\"na\">ref=<\/span><span class=\"s\">\"STDOUT\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n            <span class=\"nt\">&lt;appender-ref<\/span> <span class=\"na\">ref=<\/span><span class=\"s\">\"FILE\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/root&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/springProfile&gt;<\/span>\r\n\r\n<span class=\"nt\">&lt;\/configuration&gt;<\/span>\r\n<\/code><\/pre>\n<details>\u8bf4\u660elogback-spring.xml \u9009\u5b9a\u90e8\u5206<\/p>\n<p>\u8fd9\u4e2a\u914d\u7f6e\u6587\u4ef6\u5305\u542b\u4e86Spring Boot\u65e5\u5fd7\u7684\u9ed8\u8ba4\u914d\u7f6e\u6587\u4ef6\u3002<br \/>\n\u5b98\u65b9\u7684Spring Boot\u65e5\u5fd7\u9ed8\u8ba4\u914d\u7f6e<\/p>\n<p>logback-spring.xml \u9009\u5b9a\u90e8\u5206<br \/>\n[%-5le] %lo{0}.%M:%L &#8211; %msg%n<\/p>\n<p>\u8fd9\u4e2a\u914d\u7f6e\u6307\u5b9a\u4e86\u65e5\u5fd7\u8f93\u51fa\u7684\u683c\u5f0f\u3002<\/p>\n<p>\u8868\u8fbe<br \/>\n\u610f\u4e49<\/p>\n<p>%le<br \/>\n\u65e5\u5fd7\u4e8b\u4ef6\u7684\u7ea7\u522b<\/p>\n<p>%lo<br \/>\n\u65e5\u5fd7\u540d\u79f0<\/p>\n<p>%M<br \/>\n\u65b9\u6cd5\u540d\u79f0<\/p>\n<p>%L<br \/>\n\u884c\u53f7<\/p>\n<p>%msg<br \/>\n\u65e5\u5fd7\u6d88\u606f\u4e3b\u4f53<\/p>\n<p>%n<br \/>\n\u6362\u884c<\/p>\n<p>logback-spring.xml<br \/>\n%date{yyyy-MM-dd HH:mm:ss.SSS} [%-5le] [%t] %C.%M:%L &#8211; %m%n<\/p>\n<p>\u8fd9\u4e2a\u914d\u7f6e\u6307\u5b9a\u4e86\u65e5\u5fd7\u8f93\u51fa\u7684\u683c\u5f0f\u3002<\/p>\n<p>\u8868\u8fbe<br \/>\n\u610f\u4e49<\/p>\n<p>%date{yyyy-MM-dd HHss.SSS}<br \/>\n\u4ee5\u6307\u5b9a\u7684\u683c\u5f0f\u663e\u793a\u8bb0\u5f55\u8f93\u51fa\u7684\u65e5\u671f\u548c\u65f6\u95f4\u3002<\/p>\n<p>%-5le<br \/>\n\u57285\u4e2a\u5b57\u7b26\u7684\u5bbd\u5ea6\u4e2d\u663e\u793a\u65e5\u5fd7\u7ea7\u522b\u3002%-5\u662f\u7528\u4e8e\u6307\u5b9a\u5de6\u5bf9\u9f50\u7684\u6807\u5fd7\u3002<\/p>\n<p>%t<br \/>\n\u663e\u793a\u8bb0\u5f55\u8f93\u51fa\u7684\u7ebf\u7a0b\u540d\u79f0\u3002<\/p>\n<p>%C.%M:%L<br \/>\n\u663e\u793a\u8bb0\u5f55\u8f93\u51fa\u7684\u7c7b\u3001\u65b9\u6cd5\u548c\u884c\u53f7\u3002<\/p>\n<p>%m<br \/>\n\u663e\u793a\u65e5\u5fd7\u6d88\u606f\u3002<\/p>\n<p>%n<br \/>\n\u63d2\u5165\u6362\u884c\u3002<\/p>\n<p>logback-spring.xml \u9009\u5b9a\u90e8\u5206<\/p>\n<p>.\/log\/app.%d{yyyy-MM-dd}_%i.log.gz<\/p>\n<p>5MB<\/p>\n<p>31<br \/>\ntrue<\/p>\n<p>\u8fd9\u4e2a\u914d\u7f6e\u6307\u5b9a\u4e86\u6309\u65f6\u95f4\u95f4\u9694\u8fdb\u884c\u65e5\u5fd7\u6587\u4ef6\u7684\u8f6e\u8f6c\u65b9\u5f0f\u3002<\/p>\n<p>\u65e5\u5fd7\u6587\u4ef6\u540d\u6839\u636e .\/log\/app.%d{yyyy-MM-dd}_%i.log.gz \u6587\u4ef6\u540d\u6a21\u5f0f\u547d\u540d\u3002<br \/>\n\u540c\u65f6\u4f7f\u7528 SizeAndTimeBasedFNATP \u7c7b\u6765\u8bbe\u7f6e\u57fa\u4e8e\u6587\u4ef6\u5927\u5c0f\u548c\u65f6\u95f4\u7684\u8f6e\u8f6c\u3002<br \/>\n\u65e5\u5fd7\u6587\u4ef6\u7684\u6700\u5927\u5927\u5c0f\u8bbe\u5b9a\u4e3a5MB\uff0c\u5e76\u4f7f\u7528maxHistory\u5c5e\u6027\u8bbe\u7f6e\u65e5\u5fd7\u6587\u4ef6\u7684\u6700\u5927\u4fdd\u5b58\u5929\u6570\u4e3a31\u5929\u3002<br \/>\ncleanHistoryOnStart\u5c5e\u6027\u8bbe\u7f6e\u662f\u5426\u5728\u5e94\u7528\u542f\u52a8\u65f6\u81ea\u52a8\u5220\u9664\u65e7\u7684\u65e5\u5fd7\u6587\u4ef6\u3002<\/p>\n<\/details>\n<h3>\u5728Java\u4ee3\u7801\u4e2d\u6dfb\u52a0\u8f93\u51fa\u65e5\u5fd7\u7684\u4ee3\u7801<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>vim src\/main\/java\/com\/example\/spring\/SpringbootApplication.java\r\n<\/code><\/pre>\n<p>\u6587\u4ef6\u7684\u5185\u5bb9 de<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">com.example.spring<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.Logger<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.slf4j.LoggerFactory<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.boot.SpringApplication<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.boot.autoconfigure.SpringBootApplication<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.web.bind.annotation.GetMapping<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.web.bind.annotation.RestController<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"nd\">@RestController<\/span>\r\n<span class=\"nd\">@SpringBootApplication<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">SpringbootApplication<\/span> <span class=\"o\">{<\/span>\r\n\r\n    <span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">Logger<\/span> <span class=\"n\">log<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">LoggerFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">getLogger<\/span><span class=\"o\">(<\/span><span class=\"nc\">SpringbootApplication<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"kd\">static<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">main<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span><span class=\"o\">[]<\/span> <span class=\"n\">args<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">SpringApplication<\/span><span class=\"o\">.<\/span><span class=\"na\">run<\/span><span class=\"o\">(<\/span><span class=\"nc\">SpringbootApplication<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">,<\/span> <span class=\"n\">args<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nd\">@GetMapping<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\/hello\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">String<\/span> <span class=\"nf\">hello<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"n\">log<\/span><span class=\"o\">.<\/span><span class=\"na\">info<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Hello World!\"<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"s\">\"Hello World!\"<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<details>\u8bf4\u660eSpringbootApplication.java \u203b\u6458\u5f55\u90e8\u5206<br \/>\nimport org.slf4j.Logger;<br \/>\nimport org.slf4j.LoggerFactory;<\/p>\n<p>\u6211\u4eec\u5bfc\u5165\u4e86\u4f7f\u7528SLF4J\u8f93\u51faJava\u65e5\u5fd7\u6240\u9700\u7684\u7c7b\u548c\u63a5\u53e3\u3002<\/p>\n<p>SpringbootApplication.java \u203b\u6458\u5f55\u90e8\u5206<br \/>\nprivate static final Logger log = LoggerFactory.getLogger(SpringbootApplication.class);<\/p>\n<p>LoggerFactory.getLogger()\u65b9\u6cd5\u9700\u8981\u4f20\u5165\u4f7f\u7528\u65e5\u5fd7\u529f\u80fd\u7684\u7c7b\u7684\u540d\u79f0\u3002\u901a\u5e38\u60c5\u51b5\u4e0b\uff0c\u6211\u4eec\u4f1a\u6839\u636e\u7c7b\u6765\u5b9a\u4e49\u65e5\u5fd7\u8bb0\u5f55\u5668\uff0c\u6240\u4ee5\u9700\u8981\u6307\u5b9a\u5b8c\u5168\u9650\u5b9a\u540d\u3002\u8fd9\u4e2a\u65e5\u5fd7\u8bb0\u5f55\u5668\u5bf9\u8c61\u5c06\u901a\u8fc7SLF4J\u6765\u5b9e\u73b0\u65e5\u5fd7\u8f93\u51fa\u3002<\/p>\n<p>SpringbootApplication.java \u203b\u6458\u5f55\u90e8\u5206<br \/>\nlog.info(&#8220;Hello World!&#8221;);<\/p>\n<p>\u6211\u4eec\u4f7f\u7528SLF4J\u7684Logger\u63a5\u53e3\u7684info()\u65b9\u6cd5\u6765\u5411\u65e5\u5fd7\u8f93\u51fa\u4fe1\u606f&#8221;Hello World!&#8221;\u3002<\/p>\n<p>SLF4J\u7684\u65e5\u5fd7\u7ea7\u522b<\/p>\n<p>\u7ea7\u522b<br \/>\n\u6982\u89c8<\/p>\n<p>TRACE<br \/>\n\u7528\u4e8e\u8c03\u8bd5\u7684\u975e\u5e38\u8be6\u7ec6\u7684\u4fe1\u606f<\/p>\n<p>DEBUG<br \/>\n\u8c03\u8bd5\u4fe1\u606f<\/p>\n<p>INFO<br \/>\n\u4e00\u822c\u4fe1\u606f<\/p>\n<p>WARN<br \/>\n\u8b66\u544a\u4fe1\u606f<\/p>\n<p>ERROR<br \/>\n\u9519\u8bef\u4fe1\u606f<\/p>\n<p>FATAL<br \/>\n\u81f4\u547d\u9519\u8bef<\/p>\n<\/details>\n<h3>\u76ee\u5f55\u6587\u4ef6\u7ed3\u6784<\/h3>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>tree <span class=\"nt\">-I<\/span> log <span class=\"nt\">-I<\/span> target\r\n<span class=\"nb\">.<\/span>\r\n\u251c\u2500\u2500 pom.xml\r\n\u2514\u2500\u2500 src\r\n    \u2514\u2500\u2500 main\r\n        \u251c\u2500\u2500 java\r\n        \u2502\u00a0\u00a0 \u2514\u2500\u2500 com\r\n        \u2502\u00a0\u00a0     \u2514\u2500\u2500 example\r\n        \u2502\u00a0\u00a0         \u2514\u2500\u2500 spring\r\n        \u2502\u00a0\u00a0             \u2514\u2500\u2500 SpringbootApplication.java\r\n        \u2514\u2500\u2500 resources\r\n            \u251c\u2500\u2500 application.properties\r\n            \u2514\u2500\u2500 logback-spring.xml\r\n<\/code><\/pre>\n<h4>\u8fd0\u884cSpring Boot\u5e94\u7528<\/h4>\n<p>Java \u5e94\u7528\u7a0b\u5e8f\u6784\u5efa<\/p>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>mvn clean <span class=\"nb\">install<\/span>\r\n<\/code><\/pre>\n<p>\u4f7f\u7528Java\u542f\u52a8\u5e94\u7528\u7a0b\u5e8f\uff08\u6309Ctrl + C\u505c\u6b62\uff09<\/p>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>mvn spring-boot:run\r\n<\/code><\/pre>\n<p>\u8bf7\u4f7f\u7528\u5176\u4ed6\u7ec8\u7aef\u547d\u4ee4\u8fdb\u884c\u786e\u8ba4\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>curl http:\/\/localhost:8080\/hello\r\nHello World!\r\n<\/code><\/pre>\n<p>\u5728\u7ec8\u7aef\u4e0a\u663e\u793a\u4e86\u4ee5\u4e0b\u65e5\u5fd7\u4fe1\u606f\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"o\">[<\/span>INFO <span class=\"o\">]<\/span> SpringbootApplication.hello:23 - Hello World!\r\n<\/code><\/pre>\n<p>\u53e6\u5916\uff0c\u4ee5\u4e0b\u5185\u5bb9\u5df2\u5728\/log\/app.log\u4e2d\u8bb0\u5f55\u3002<\/p>\n<pre class=\"post-pre\"><code>2023-02-21 17:25:33.785 <span class=\"o\">[<\/span>INFO <span class=\"o\">]<\/span> <span class=\"o\">[<\/span>http-nio-8080-exec-1] com.example.spring.SpringbootApplication.hello:23 - Hello World!\r\n<\/code><\/pre>\n<h3>\u8bbe\u7f6e\u5f02\u6b65\u8f93\u51fa\u65e5\u5fd7<\/h3>\n<details>\u5c55\u5f00\u6b64 example\uff0c\u5c55\u793a FILE appender \u548c STDOUT appender \u7684\u5f02\u6b65\u8c03\u7528\u7684\u914d\u7f6e\u3002\u6307\u5b9a AsyncAppender \u4f7f\u7528\u7684\u961f\u5217\u7684\u5927\u5c0f\u3002\u961f\u5217\u7528\u4e8e\u4e34\u65f6\u5b58\u50a8\u65e5\u5fd7\u4e8b\u4ef6\u3002\u53ef\u4ee5\u6839\u636e\u9700\u8981\u8c03\u6574\u8bbe\u7f6e\u503c\uff0c\u4f46\u662f\u5982\u679c\u5c06\u8bbe\u7f6e\u503c\u8bbe\u5f97\u592a\u5927\uff0c\u53ef\u80fd\u4f1a\u589e\u52a0\u5185\u5b58\u6d88\u8017\u3002<\/p>\n<p>\u63a7\u5236\u5f53\u961f\u5217\u5df2\u6ee1\u65f6\u662f\u5426\u963b\u585e\u65e5\u5fd7\u4e8b\u4ef6\u7684\u5904\u7406\u3002\u5982\u679c\u6b64\u503c\u4e3a true\uff0c\u5728\u961f\u5217\u5df2\u6ee1\u7684\u60c5\u51b5\u4e0b\uff0c\u4e0d\u4f1a\u963b\u585e\u65e5\u5fd7\u4e8b\u4ef6\u5e76\u4e14\u4f1a\u4e22\u5f03\u3002\u5982\u679c\u4e3a false\uff0c\u5728\u961f\u5217\u5df2\u6ee1\u7684\u60c5\u51b5\u4e0b\uff0c\u4f1a\u963b\u585e\u65e5\u5fd7\u4e8b\u4ef6\u3002<\/p>\n<p>\u662f\u7528\u4e8e\u914d\u7f6e Logback \u7684\u65e5\u5fd7\u4e8b\u4ef6\u662f\u5426\u5305\u542b\u8c03\u7528\u8005\u6570\u636e\uff08caller data\uff09\u7684\u8bbe\u7f6e\u3002\u8c03\u7528\u8005\u6570\u636e\u6307\u7684\u662f\u6307\u793a\u65e5\u5fd7\u4e8b\u4ef6\u53d1\u751f\u4f4d\u7f6e\uff08\u7c7b\u540d\u3001\u65b9\u6cd5\u540d\u3001\u884c\u53f7\uff09\u7684\u4fe1\u606f\u3002\u901a\u8fc7\u542f\u7528\u6b64\u8bbe\u7f6e\uff0c\u53ef\u4ee5\u5c06\u8c03\u7528\u8005\u6570\u636e\u5305\u542b\u5728\u65e5\u5fd7\u4e8b\u4ef6\u4e2d\u3002\u7136\u800c\uff0c\u4ece\u6027\u80fd\u65b9\u9762\u8003\u8651\uff0c\u5728\u4f7f\u7528\u5f02\u6b65 appender \u65f6\u9700\u8981\u6ce8\u610f\u6b64\u8bbe\u7f6e\u3002<\/p>\n<\/details>\n<h2>\u7b80\u8981\u603b\u7ed3<\/h2>\n<ul class=\"post-ul\">Ubuntu \u306e \u6700\u5c0f\u69cb\u6210\u306e Java \u958b\u767a\u74b0\u5883\u3067 Spring Boot \u30a2\u30d7\u30ea\u306b\u30ed\u30b0\u51fa\u529b\u6a5f\u80fd\u3092\u7d44\u307f\u3053\u3080\u3053\u3068\u304c\u51fa\u6765\u307e\u3057\u305f\u3002<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u4f7f\u7528Spring Boot\u8f93\u51fa\u65e5\u5fd7\u7684\u65b9\u6cd5 \u89e3\u91ca\u7684\u76ee\u7684\u662f\u4ec0\u4e48\uff1f \u5b66\u4e60\u5e76\u6df1\u5165\u7406\u89e3\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7 [&hellip;]<\/p>\n","protected":false},"author":8,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-39836","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u5982\u4f55\u5728spring-boot\u4e2d\u8f93\u51fa\u65e5\u5fd7\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7\" \/>\n<meta property=\"og:description\" content=\"\u4f7f\u7528Spring Boot\u8f93\u51fa\u65e5\u5fd7\u7684\u65b9\u6cd5 \u89e3\u91ca\u7684\u76ee\u7684\u662f\u4ec0\u4e48\uff1f \u5b66\u4e60\u5e76\u6df1\u5165\u7406\u89e3\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u5982\u4f55\u5728spring-boot\u4e2d\u8f93\u51fa\u65e5\u5fd7\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-08-31T04:37:40+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-05-04T09:08:37+00:00\" \/>\n<meta name=\"author\" content=\"\u96c5, \u609f\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u96c5, \u609f\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"6 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/\",\"name\":\"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-08-31T04:37:40+00:00\",\"dateModified\":\"2024-05-04T09:08:37+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6\",\"name\":\"\u96c5, \u609f\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g\",\"caption\":\"\u96c5, \u609f\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yawu\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u5982\u4f55\u5728spring-boot\u4e2d\u8f93\u51fa\u65e5\u5fd7\/","og_locale":"zh_CN","og_type":"article","og_title":"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7","og_description":"\u4f7f\u7528Spring Boot\u8f93\u51fa\u65e5\u5fd7\u7684\u65b9\u6cd5 \u89e3\u91ca\u7684\u76ee\u7684\u662f\u4ec0\u4e48\uff1f \u5b66\u4e60\u5e76\u6df1\u5165\u7406\u89e3\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7 [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u5982\u4f55\u5728spring-boot\u4e2d\u8f93\u51fa\u65e5\u5fd7\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-08-31T04:37:40+00:00","article_modified_time":"2024-05-04T09:08:37+00:00","author":"\u96c5, \u609f","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u96c5, \u609f","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"6 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/","name":"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-08-31T04:37:40+00:00","dateModified":"2024-05-04T09:08:37+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u5982\u4f55\u5728Spring Boot\u4e2d\u8f93\u51fa\u65e5\u5fd7"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6","name":"\u96c5, \u609f","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g","caption":"\u96c5, \u609f"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yawu\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%a6%82%e4%bd%95%e5%9c%a8spring-boot%e4%b8%ad%e8%be%93%e5%87%ba%e6%97%a5%e5%bf%97\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39836","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/8"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=39836"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39836\/revisions"}],"predecessor-version":[{"id":99601,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/39836\/revisions\/99601"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=39836"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=39836"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=39836"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}