blob: c74d54162887679d8cc99b73964e44c859b1722c [file] [log] [blame]
"use strict";(self.webpackChunkrocketmq_docs=self.webpackChunkrocketmq_docs||[]).push([[9348],{15680:(e,t,n)=>{n.d(t,{xA:()=>g,yg:()=>m});var r=n(96540);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function l(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function o(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?l(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):l(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function c(e,t){if(null==e)return{};var n,r,a=function(e,t){if(null==e)return{};var n,r,a={},l=Object.keys(e);for(r=0;r<l.length;r++)n=l[r],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var l=Object.getOwnPropertySymbols(e);for(r=0;r<l.length;r++)n=l[r],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=r.createContext({}),u=function(e){var t=r.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},g=function(e){var t=u(e.components);return r.createElement(i.Provider,{value:t},e.children)},p="mdxType",s={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,a=e.mdxType,l=e.originalType,i=e.parentName,g=c(e,["components","mdxType","originalType","parentName"]),p=u(n),d=a,m=p["".concat(i,".").concat(d)]||p[d]||s[d]||l;return n?r.createElement(m,o(o({ref:t},g),{},{components:n})):r.createElement(m,o({ref:t},g))}));function m(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var l=n.length,o=new Array(l);o[0]=d;var c={};for(var i in t)hasOwnProperty.call(t,i)&&(c[i]=t[i]);c.originalType=e,c[p]="string"==typeof e?e:a,o[1]=c;for(var u=2;u<l;u++)o[u]=n[u];return r.createElement.apply(null,o)}return r.createElement.apply(null,n)}d.displayName="MDXCreateElement"},19365:(e,t,n)=>{n.d(t,{A:()=>o});var r=n(96540),a=n(20053);const l={tabItem:"tabItem_Ymn6"};function o(e){let{children:t,hidden:n,className:o}=e;return r.createElement("div",{role:"tabpanel",className:(0,a.A)(l.tabItem,o),hidden:n},t)}},11470:(e,t,n)=>{n.d(t,{A:()=>I});var r=n(58168),a=n(96540),l=n(20053),o=n(23104),c=n(56347),i=n(57485),u=n(31682),g=n(89466);function p(e){return function(e){return a.Children.map(e,(e=>{if(!e||(0,a.isValidElement)(e)&&function(e){const{props:t}=e;return!!t&&"object"==typeof t&&"value"in t}(e))return e;throw new Error(`Docusaurus error: Bad <Tabs> child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the <Tabs> component should be <TabItem>, and every <TabItem> should have a unique "value" prop.`)}))?.filter(Boolean)??[]}(e).map((e=>{let{props:{value:t,label:n,attributes:r,default:a}}=e;return{value:t,label:n,attributes:r,default:a}}))}function s(e){const{values:t,children:n}=e;return(0,a.useMemo)((()=>{const e=t??p(n);return function(e){const t=(0,u.X)(e,((e,t)=>e.value===t.value));if(t.length>0)throw new Error(`Docusaurus error: Duplicate values "${t.map((e=>e.value)).join(", ")}" found in <Tabs>. Every value needs to be unique.`)}(e),e}),[t,n])}function d(e){let{value:t,tabValues:n}=e;return n.some((e=>e.value===t))}function m(e){let{queryString:t=!1,groupId:n}=e;const r=(0,c.W6)(),l=function(e){let{queryString:t=!1,groupId:n}=e;if("string"==typeof t)return t;if(!1===t)return null;if(!0===t&&!n)throw new Error('Docusaurus error: The <Tabs> component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return n??null}({queryString:t,groupId:n});return[(0,i.aZ)(l),(0,a.useCallback)((e=>{if(!l)return;const t=new URLSearchParams(r.location.search);t.set(l,e),r.replace({...r.location,search:t.toString()})}),[l,r])]}function y(e){const{defaultValue:t,queryString:n=!1,groupId:r}=e,l=s(e),[o,c]=(0,a.useState)((()=>function(e){let{defaultValue:t,tabValues:n}=e;if(0===n.length)throw new Error("Docusaurus error: the <Tabs> component requires at least one <TabItem> children component");if(t){if(!d({value:t,tabValues:n}))throw new Error(`Docusaurus error: The <Tabs> has a defaultValue "${t}" but none of its children has the corresponding value. Available values are: ${n.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return t}const r=n.find((e=>e.default))??n[0];if(!r)throw new Error("Unexpected error: 0 tabValues");return r.value}({defaultValue:t,tabValues:l}))),[i,u]=m({queryString:n,groupId:r}),[p,y]=function(e){let{groupId:t}=e;const n=function(e){return e?`docusaurus.tab.${e}`:null}(t),[r,l]=(0,g.Dv)(n);return[r,(0,a.useCallback)((e=>{n&&l.set(e)}),[n,l])]}({groupId:r}),f=(()=>{const e=i??p;return d({value:e,tabValues:l})?e:null})();(0,a.useLayoutEffect)((()=>{f&&c(f)}),[f]);return{selectedValue:o,selectValue:(0,a.useCallback)((e=>{if(!d({value:e,tabValues:l}))throw new Error(`Can't select invalid tab value=${e}`);c(e),u(e),y(e)}),[u,y,l]),tabValues:l}}var f=n(92303);const b={tabList:"tabList__CuJ",tabItem:"tabItem_LNqP"};function v(e){let{className:t,block:n,selectedValue:c,selectValue:i,tabValues:u}=e;const g=[],{blockElementScrollPositionUntilNextRender:p}=(0,o.a_)(),s=e=>{const t=e.currentTarget,n=g.indexOf(t),r=u[n].value;r!==c&&(p(t),i(r))},d=e=>{let t=null;switch(e.key){case"Enter":s(e);break;case"ArrowRight":{const n=g.indexOf(e.currentTarget)+1;t=g[n]??g[0];break}case"ArrowLeft":{const n=g.indexOf(e.currentTarget)-1;t=g[n]??g[g.length-1];break}}t?.focus()};return a.createElement("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,l.A)("tabs",{"tabs--block":n},t)},u.map((e=>{let{value:t,label:n,attributes:o}=e;return a.createElement("li",(0,r.A)({role:"tab",tabIndex:c===t?0:-1,"aria-selected":c===t,key:t,ref:e=>g.push(e),onKeyDown:d,onClick:s},o,{className:(0,l.A)("tabs__item",b.tabItem,o?.className,{"tabs__item--active":c===t})}),n??t)})))}function N(e){let{lazy:t,children:n,selectedValue:r}=e;const l=(Array.isArray(n)?n:[n]).filter(Boolean);if(t){const e=l.find((e=>e.props.value===r));return e?(0,a.cloneElement)(e,{className:"margin-top--md"}):null}return a.createElement("div",{className:"margin-top--md"},l.map(((e,t)=>(0,a.cloneElement)(e,{key:t,hidden:e.props.value!==r}))))}function h(e){const t=y(e);return a.createElement("div",{className:(0,l.A)("tabs-container",b.tabList)},a.createElement(v,(0,r.A)({},e,t)),a.createElement(N,(0,r.A)({},e,t)))}function I(e){const t=(0,f.A)();return a.createElement(h,(0,r.A)({key:String(t)},e))}},41576:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>g,contentTitle:()=>i,default:()=>m,frontMatter:()=>c,metadata:()=>u,toc:()=>p});var r=n(58168),a=(n(96540),n(15680)),l=n(11470),o=n(19365);const c={},i="\u65e5\u5fd7\u914d\u7f6e",u={unversionedId:"bestPractice/06log",id:"bestPractice/06log",title:"\u65e5\u5fd7\u914d\u7f6e",description:"\u5ba2\u6237\u7aef\u65e5\u5fd7\u7528\u4e8e\u8bb0\u5f55\u5ba2\u6237\u7aef\u8fd0\u884c\u8fc7\u7a0b\u4e2d\u7684\u5f02\u5e38\uff0c\u5e2e\u52a9\u5feb\u901f\u5b9a\u4f4d\u548c\u4fee\u590d\u95ee\u9898\u3002\u672c\u6587\u4ecb\u7ecd RocketMQ \u7684\u5ba2\u6237\u7aef\u65e5\u5fd7\u7684\u6253\u5370\u65b9\u5f0f\uff0c\u4ee5\u53ca\u9ed8\u8ba4\u548c\u81ea\u5b9a\u4e49\u914d\u7f6e\u3002",source:"@site/docs/05-bestPractice/06log.md",sourceDirName:"05-bestPractice",slug:"/bestPractice/06log",permalink:"/zh/docs/4.x/bestPractice/06log",draft:!1,editUrl:"https://github.com/apache/rocketmq-site/tree/new-official-website/docs/05-bestPractice/06log.md",tags:[],version:"current",frontMatter:{},sidebar:"myAutogeneratedSidebar",previous:{title:"JVM/OS\u914d\u7f6e",permalink:"/zh/docs/4.x/bestPractice/05JVMOS"},next:{title:"\u8ba2\u9605\u5173\u7cfb\u4e00\u81f4",permalink:"/zh/docs/4.x/bestPractice/07subscribe"}},g={},p=[{value:"\u6253\u5370\u5ba2\u6237\u7aef\u65e5\u5fd7",id:"\u6253\u5370\u5ba2\u6237\u7aef\u65e5\u5fd7",level:2},{value:"\u65b9\u5f0f\u4e00: \u4f9d\u8d56 log4j \u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0",id:"\u65b9\u5f0f\u4e00-\u4f9d\u8d56-log4j-\u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0",level:3},{value:"\u65b9\u5f0f\u4e8c: \u4f9d\u8d56 logback \u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0",id:"\u65b9\u5f0f\u4e8c-\u4f9d\u8d56-logback-\u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0",level:3},{value:"\u5ba2\u6237\u7aef\u65e5\u5fd7\u914d\u7f6e",id:"\u5ba2\u6237\u7aef\u65e5\u5fd7\u914d\u7f6e",level:2},{value:"\u9ed8\u8ba4\u914d\u7f6e",id:"\u9ed8\u8ba4\u914d\u7f6e",level:2},{value:"\u81ea\u5b9a\u4e49\u914d\u7f6e",id:"\u81ea\u5b9a\u4e49\u914d\u7f6e",level:2},{value:"\u793a\u4f8b",id:"\u793a\u4f8b",level:2}],s={toc:p},d="wrapper";function m(e){let{components:t,...n}=e;return(0,a.yg)(d,(0,r.A)({},s,n,{components:t,mdxType:"MDXLayout"}),(0,a.yg)("h1",{id:"\u65e5\u5fd7\u914d\u7f6e"},"\u65e5\u5fd7\u914d\u7f6e"),(0,a.yg)("p",null,"\u5ba2\u6237\u7aef\u65e5\u5fd7\u7528\u4e8e\u8bb0\u5f55\u5ba2\u6237\u7aef\u8fd0\u884c\u8fc7\u7a0b\u4e2d\u7684\u5f02\u5e38\uff0c\u5e2e\u52a9\u5feb\u901f\u5b9a\u4f4d\u548c\u4fee\u590d\u95ee\u9898\u3002\u672c\u6587\u4ecb\u7ecd RocketMQ \u7684\u5ba2\u6237\u7aef\u65e5\u5fd7\u7684\u6253\u5370\u65b9\u5f0f\uff0c\u4ee5\u53ca\u9ed8\u8ba4\u548c\u81ea\u5b9a\u4e49\u914d\u7f6e\u3002 "),(0,a.yg)("h2",{id:"\u6253\u5370\u5ba2\u6237\u7aef\u65e5\u5fd7"},"\u6253\u5370\u5ba2\u6237\u7aef\u65e5\u5fd7"),(0,a.yg)("p",null,"RocketMQ \u7684 TCP Java SDK \u57fa\u4e8e SLF4J \u63a5\u53e3\u7f16\u7a0b\u3002 "),(0,a.yg)("ul",null,(0,a.yg)("li",{parentName:"ul"},"\u9488\u5bf9 JavaSDK1.7.8.Final \u7248\u672c\u53ca\u4ee5\u4e0a ")),(0,a.yg)("p",null,"RocketMQ \u7684 Java SDK 1.7.8.Final \u5df2\u5185\u7f6e\u4e86\u65e5\u5fd7\u5b9e\u73b0\uff0c\u65e0\u9700\u5728\u5ba2\u6237\u7aef\u5e94\u7528\u4e2d\u6dfb\u52a0\u65e5\u5fd7\u5b9e\u73b0\u4f9d\u8d56 \u5373\u53ef\u6253\u5370 RocketMQ \u5ba2\u6237\u7aef\u65e5\u5fd7\u3002\nRocketMQ\u5ba2\u6237\u7aef\u65e5\u5fd7\u7684\u9ed8\u8ba4\u914d\u7f6e\u548c\u5982\u4f55\u4fee\u6539\u9ed8\u8ba4\u914d\u7f6e\uff0c\u8bf7\u53c2\u89c1\u4e0b\u6587\u7684\u5ba2\u6237\u7aef\u65e5\u5fd7\u914d\u7f6e\u90e8\u5206\u3002 "),(0,a.yg)("ul",null,(0,a.yg)("li",{parentName:"ul"},"\u9488\u5bf9 JavaSDK1.7.8.Final \u4ee5\u4e0b ")),(0,a.yg)("p",null,"RocketMQ \u7684Java SDK 1.7.8.Final \u4ee5\u4e0b\u7684\u65e7\u7248\u672c\u4e0d\u652f\u6301 log4j2\uff0c\u53ea\u652f\u6301 log4j\u3001logback\u3002\u60a8\u9700\u8981 \u5728 pom.xml \u914d\u7f6e\u6587\u4ef6 \u6216\u8005 lib \u4e2d\u6dfb\u52a0\u5bf9\u5e94\u7684\u65e5\u5fd7\u5b9e\u73b0\u4f9d\u8d56\u6765\u6253\u5370 RocketMQ \u5ba2\u6237\u7aef\u65e5\u5fd7\u3002 "),(0,a.yg)("h3",{id:"\u65b9\u5f0f\u4e00-\u4f9d\u8d56-log4j-\u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0"},"\u65b9\u5f0f\u4e00: \u4f9d\u8d56 log4j \u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0"),(0,a.yg)("p",null,"\u4f9d\u8d56log4j\u6216logback\u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0\u7684\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\u6240\u793a\u3002"),(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre",className:"language-xml"},"<dependency> \n <groupId>org.slf4j</groupId> \n <artifactId>jcl-over-slf4j</artifactId> \n <version>1.7.7</version>\n</dependency> \n<dependency>\n <groupId>org.slf4j</groupId>\n <artifactId>slf4j-log4j12</artifactId>\n <version>1.7.7</version>\n</dependency> \n<dependency>\n <groupId>log4j</groupId> \n <artifactId>log4j</artifactId>\n <version>1.2.17</version> \n</dependency>\n")),(0,a.yg)("p",null,"\u4f7f\u7528 log4j \u5c5e\u6027\u914d\u7f6e\u6587\u4ef6\u65f6\uff0c\u914d\u7f6e\u5982\u4e0b\u3002"),(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre",className:"language-properties"},"log4j.appender.mq=org.apache.rocketmq.logappender.log4j.RocketmqLog4jAppender \nlog4j.appender.mq.Tag=yourTag \nlog4j.appender.mq.Topic=yourLogTopic \nlog4j.appender.mq.ProducerGroup=yourLogGroup \nlog4j.appender.mq.NameServerAddress=yourRocketmqNameserverAddress \nlog4j.appender.mq.layout=org.apache.log4j.PatternLayout \nlog4j.appender.mq.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-4r [%t] (%F:%L) %-5p - %m%n \n")),(0,a.yg)("p",null,"\u4f7f\u7528 log4j xml \u914d\u7f6e\u6587\u4ef6\u65f6\uff0c\u5c06\u5176\u914d\u7f6e\u4e3a\u8fd9\u6837\u5e76\u6dfb\u52a0\u4e00\u4e2a\u5f02\u6b65\u9644\u52a0\u7a0b\u5e8f\uff1a"),(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre",className:"language-xml"},'<appender name="mqAppender1" class="org.apache.rocketmq.logappender.log4j.RocketmqLog4jAppender">\n <param name="Tag" value="yourTag" />\n <param name="Topic" value="yourLogTopic" />\n <param name="ProducerGroup" value="yourLogGroup" />\n <param name="NameServerAddress" value="yourRocketmqNameserverAddress"/>\n <layout class="org.apache.log4j.PatternLayout">\n <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}-%p %t %c - %m%n" />\n </layout>\n</appender>\n\n<appender name="mqAsyncAppender1" class="org.apache.log4j.AsyncAppender">\n <param name="BufferSize" value="1024" />\n <param name="Blocking" value="false" />\n <appender-ref ref="mqAppender1"/>\n</appender>\n')),(0,a.yg)("p",null,"\u4f7f\u7528 log4j2 \u65f6\uff0c\u914d\u7f6e\u4e3a this\u3002\u5982\u679c\u4f60\u60f3\u8981 noneblock\uff0c\u53ea\u9700\u4e3a ref \u914d\u7f6e\u4e00\u4e2a asyncAppender\u3002"),(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre",className:"language-xml"},'<RocketMQ name="rocketmqAppender" producerGroup="yourLogGroup" nameServerAddress="yourRocketmqNameserverAddress"\n topic="yourLogTopic" tag="yourTag">\n <PatternLayout pattern="%d [%p] hahahah %c %m%n"/>\n</RocketMQ>\n')),(0,a.yg)("h3",{id:"\u65b9\u5f0f\u4e8c-\u4f9d\u8d56-logback-\u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0"},"\u65b9\u5f0f\u4e8c: \u4f9d\u8d56 logback \u4f5c\u4e3a\u65e5\u5fd7\u5b9e\u73b0"),(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre",className:"language-xml"},"<dependency> \n <groupId>ch.qos.logback</groupId> \n <artifactId>logback-core</artifactId> \n <version>1.1.2</version>\n</dependency> \n<dependency>\n <groupId>ch.qos.logback</groupId>\n <artifactId>logback-classic</artifactId> \n <version>1.1.2</version> \n</dependency>\n")),(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre",className:"language-xml"},"<dependency> \n <groupId>ch.qos.logback</groupId> \n <artifactId>logback-core</artifactId> \n <version>1.1.2</version>\n</dependency> \n<dependency>\n <groupId>ch.qos.logback</groupId>\n <artifactId>logback-classic</artifactId> \n <version>1.1.2</version> \n</dependency>\n")),(0,a.yg)("admonition",{type:"tip"},(0,a.yg)("p",{parentName:"admonition"},"\u5e94\u7528\u4e2d\u540c\u65f6\u4f9d\u8d56log4j\u548clogback\u7684\u65e5\u5fd7\u5b9e\u73b0\u4f1a\u9020\u6210\u65e5\u5fd7\u51b2\u7a81\u5bfc\u81f4\u5ba2\u6237\u7aef\u65e5\u5fd7\u6253\u5370\u6df7\u4e71\u3002\u786e\u4fdd \u5e94\u7528\u53ea\u4f9d\u8d56\u5176\u4e2d\u4e00\u4e2a\u65e5\u5fd7\u5b9e\u73b0\uff0c\u662f\u6b63\u786e\u6253\u5370RocketMQ\u5ba2\u6237\u7aef\u65e5\u5fd7\u7684\u524d\u63d0\u6761\u4ef6\uff0c\u5efa\u8bae\u901a\u8fc7",(0,a.yg)("inlineCode",{parentName:"p"},"mvn \nclean dependency:tree | grep log"),"\u547d\u4ee4\u6392\u67e5\u3002 ")),(0,a.yg)("h2",{id:"\u5ba2\u6237\u7aef\u65e5\u5fd7\u914d\u7f6e"},"\u5ba2\u6237\u7aef\u65e5\u5fd7\u914d\u7f6e"),(0,a.yg)("p",null,"RocketMQ \u5ba2\u6237\u7aef\u652f\u6301\u81ea\u5b9a\u4e49\u65e5\u5fd7\u4fdd\u5b58\u8def\u5f84\u3001\u65e5\u5fd7\u7ea7\u522b\u4ee5\u53ca\u4fdd\u5b58\u5386\u53f2\u65e5\u5fd7\u6587\u4ef6\u7684\u6700\u5927\u4e2a\u6570\u3002\u8003\u8651\u5230\u65e5\u5fd7\u4f20\u8f93\u4ee5\u53ca\u9605\u8bfb\u7684\u4fbf\u5229\u6027\uff0c\u6682\u4e0d\u5141\u8bb8\u81ea\u5b9a\u4e49\u5355\u4e2a\u65e5\u5fd7\u6587\u4ef6\u5927\u5c0f\uff0c\u4ecd\u4fdd\u6301\u9ed8\u8ba4\u768464 MB\u3002\u5404\u53c2\u6570\u7684\u914d\u7f6e\u8bf4\u660e\u5982\u4e0b\uff1a"),(0,a.yg)("table",null,(0,a.yg)("thead",{parentName:"table"},(0,a.yg)("tr",{parentName:"thead"},(0,a.yg)("th",{parentName:"tr",align:null},"\u53c2\u6570"),(0,a.yg)("th",{parentName:"tr",align:null},"\u8bf4\u660e"),(0,a.yg)("th",{parentName:"tr",align:null},"\u914d\u7f6e\u53c2\u6570"),(0,a.yg)("th",{parentName:"tr",align:null},"\u81ea\u5b9a\u4e49\u53d6\u503c"))),(0,a.yg)("tbody",{parentName:"table"},(0,a.yg)("tr",{parentName:"tbody"},(0,a.yg)("td",{parentName:"tr",align:null},"\u65e5\u5fd7\u4fdd\u5b58\u8def\u5f84"),(0,a.yg)("td",{parentName:"tr",align:null},"\u8bf7\u786e\u4fdd\u5e94\u7528\u8fdb\u7a0b\u6709\u5bf9\u8be5\u8def\u5f84\u5199\u7684\u6743\u9650\uff0c\u5426\u5219\u65e5\u5fd7 \u4e0d\u4f1a\u6253\u5370\u3002"),(0,a.yg)("td",{parentName:"tr",align:null},"rocketmq.client.logRoot"),(0,a.yg)("td",{parentName:"tr",align:null},"\u53ef\u81ea\u5b9a\u4e49\u4e3a\u60a8\u9700\u8981\u5c06\u65e5\u5fd7\u6587\u4ef6\u4fdd\u5b58\u5230\u672c\u5730\u7684\u8def\u5f84\u3002\u8bf7\u786e\u4fdd\u60a8\u7684\u5e94\u7528\u8fdb\u7a0b\u6709\u8be5\u8def\u5f84\u7684\u5199\u6743\u9650\uff0c\u5426\u5219\u65e5\u5fd7\u65e0\u6cd5\u6253\u5370\u3002")),(0,a.yg)("tr",{parentName:"tbody"},(0,a.yg)("td",{parentName:"tr",align:null},"\u4fdd\u5b58\u5386\u53f2\u65e5\u5fd7\u6587\u4ef6\u7684\u6700\u5927\u4e2a\u6570"),(0,a.yg)("td",{parentName:"tr",align:null},"\u652f\u63011\u5230100\u4e4b\u524d\u7684\u6570\u503c;\u82e5\u8f93\u5165\u7684\u503c\u8d85\u51fa\u8be5\u8303\u56f4 \u6216\u683c\u5f0f\u9519\u8bef\uff0c\u5219\u7cfb\u7edf\u9ed8\u8ba4\u4fdd\u5b5810\u4e2a\u3002"),(0,a.yg)("td",{parentName:"tr",align:null},"rocketmq.client.logFileMaxIndex"),(0,a.yg)("td",{parentName:"tr",align:null},"\u53d6\u503c\u8303\u56f4\uff1a1~100\u3002\u82e5\u8bbe\u7f6e\u7684\u503c\u8d85\u51fa\u8be5\u8303\u56f4\u6216\u683c\u5f0f\u9519\u8bef\uff0c\u5219\u4ee5\u7cfb\u7edf\u9ed8\u8ba4\u503c\uff0810\u4e2a\uff09\u4e3a\u51c6\u3002")),(0,a.yg)("tr",{parentName:"tbody"},(0,a.yg)("td",{parentName:"tr",align:null},"\u65e5\u5fd7\u7ea7\u522b"),(0,a.yg)("td",{parentName:"tr",align:null},"\u652f\u6301ERROR\u3001WARN\u3001INFO\u3001DEBUG\u4e2d\u4efb\u4f55\u4e00 \u79cd\uff0c\u4e0d\u5339\u914d\u9ed8\u8ba4INFO\u3002"),(0,a.yg)("td",{parentName:"tr",align:null},"rocketmq.client.logLevel"),(0,a.yg)("td",{parentName:"tr",align:null},"\u53d6\u503c\u5982\u4e0b\uff1a",(0,a.yg)("strong",{parentName:"td"},"ERROR**"),"WARN*",(0,a.yg)("strong",{parentName:"td"},"*INFO**"),"DEBUG**")),(0,a.yg)("tr",{parentName:"tbody"},(0,a.yg)("td",{parentName:"tr",align:null},"\u5355\u4e2a\u6587\u4ef6\u65e5\u5fd7\u5927\u5c0f"),(0,a.yg)("td",{parentName:"tr",align:null},"\u652f\u6301\u4ee5bytes\u4e3a\u5355\u4f4d\u6307\u5b9a"),(0,a.yg)("td",{parentName:"tr",align:null},"rocketmq.client.logFileMaxSize"),(0,a.yg)("td",{parentName:"tr",align:null},"\u53d6\u503c\u57280~1GB, \u9ed8\u8ba41GB, \u5efa\u8bae64 MB")),(0,a.yg)("tr",{parentName:"tbody"},(0,a.yg)("td",{parentName:"tr",align:null},"logback\u662f\u5426\u4f7f\u7528\u7236\u7ea7logger\u6253\u5370"),(0,a.yg)("td",{parentName:"tr",align:null},"children-logger\u662f\u5426\u4f7f\u7528 rootLogger\u914d\u7f6e\u7684appender\u8fdb\u884c\u8f93\u51fa"),(0,a.yg)("td",{parentName:"tr",align:null},"rocketmq.client.log.additive"),(0,a.yg)("td",{parentName:"tr",align:null},"true/false")),(0,a.yg)("tr",{parentName:"tbody"},(0,a.yg)("td",{parentName:"tr",align:null},"\u4f7f\u7528\u9879\u76ee\u7684slf4j\u5b9e\u73b0\u8bb0\u5f55\u65e5\u5fd7"),(0,a.yg)("td",{parentName:"tr",align:null},"\u5982\u679c\u9700\u8981\u5b9e\u73b0\u8bb0\u5f55\u65e5\u5fd7 \u5219\u4e3atrue"),(0,a.yg)("td",{parentName:"tr",align:null},"rocketmq.client.logUseSlf4j"),(0,a.yg)("td",{parentName:"tr",align:null},"true/flase")))),(0,a.yg)("h2",{id:"\u9ed8\u8ba4\u914d\u7f6e"},"\u9ed8\u8ba4\u914d\u7f6e"),(0,a.yg)("p",null,"\u8bf7\u786e\u4fdd\u5e94\u7528\u8fdb\u7a0b\u6709\u5bf9\u8be5\u8def\u5f84\u5199\u7684\u6743\u9650\uff0c\u5426\u5219\u65e5\u5fd7 \u4e0d\u4f1a\u6253\u5370\u3002 \u652f\u6301 1 \u5230 100 \u4e4b\u524d\u7684\u6570\u503c;\u82e5\u8f93\u5165\u7684\u503c\u8d85\u51fa\u8be5\u8303\u56f4 \u6216\u683c\u5f0f\u9519\u8bef\uff0c\u5219\u7cfb\u7edf\u9ed8\u8ba4\u4fdd\u5b5810\u4e2a\u3002 \u652f\u6301 ERROR\u3001WARN\u3001INFO\u3001DEBUG \u4e2d\u4efb\u4f55\u4e00 \u79cd\uff0c\u4e0d\u5339\u914d\u9ed8\u8ba4 INFO\u3002 "),(0,a.yg)("p",null,"RocketMQ \u5ba2\u6237\u7aef\u542f\u52a8\u540e\uff0c\u4f1a\u6309\u7167\u5982\u4e0b\u7684\u9ed8\u8ba4\u914d\u7f6e\u751f\u6210\u65e5\u5fd7\u6587\u4ef6 :\t\t\t\t\t\t"),(0,a.yg)("ul",null,(0,a.yg)("li",{parentName:"ul"},"\u65e5\u5fd7\u4fdd\u5b58\u8def\u5f84:/{user.home}/logs/rocketmqlogs/ \u5176\u4e2d{user.home}\u662f\u6307\u542f\u52a8\u5f53\u524dJava\u8fdb\u7a0b\u7684\u7528 \u6237\u7684\u6839\u76ee\u5f55\t\t\t\t"),(0,a.yg)("li",{parentName:"ul"},"\u4fdd\u5b58\u5386\u53f2\u65e5\u5fd7\u6587\u4ef6\u7684\u6700\u5927\u4e2a\u6570:10\u4e2a \t\t\t\t\t\t"),(0,a.yg)("li",{parentName:"ul"},"\u65e5\u5fd7\u7ea7\u522b:INFO \t\t\t\t\t\t"),(0,a.yg)("li",{parentName:"ul"},"\u5355\u4e2a\u65e5\u5fd7\u6587\u4ef6\u5927\u5c0f: 1GB\t\t\t\t\t\t")),(0,a.yg)("h2",{id:"\u81ea\u5b9a\u4e49\u914d\u7f6e"},"\u81ea\u5b9a\u4e49\u914d\u7f6e"),(0,a.yg)("p",null,"\u5982\u679c\u9700\u8981\u8fdb\u884c\u81ea\u5b9a\u4e49\u914d\u7f6e \u53c2\u8003 ClientLogger\u7684\u9759\u6001\u53d8\u91cf\u5b9a\u4e49, \u53c2\u6570\u610f\u4e49\u5bf9\u9f50\u4e0a\u6587\u5ba2\u6237\u7aef\u914d\u7f6e\u3002"),(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre",className:"language-java"},' public static final String CLIENT_LOG_USESLF4J = "rocketmq.client.logUseSlf4j";\n public static final String CLIENT_LOG_ROOT = "rocketmq.client.logRoot";\n public static final String CLIENT_LOG_MAXINDEX = "rocketmq.client.logFileMaxIndex";\n public static final String CLIENT_LOG_FILESIZE = "rocketmq.client.logFileMaxSize";\n public static final String CLIENT_LOG_LEVEL = "rocketmq.client.logLevel";\n public static final String CLIENT_LOG_ADDITIVE = "rocketmq.client.log.additive";\n public static final String CLIENT_LOG_FILENAME = "rocketmq.client.logFileName";\n public static final String CLIENT_LOG_ASYNC_QUEUESIZE = "rocketmq.client.logAsyncQueueSize";\n public static final String ROCKETMQ_CLIENT_APPENDER_NAME = "RocketmqClientAppender";\n\n private static final InternalLogger CLIENT_LOGGER;\n\n private static final boolean CLIENT_USE_SLF4J;\n\n //private static Appender rocketmqClientAppender = null;\n\n static {\n CLIENT_USE_SLF4J = Boolean.parseBoolean(System.getProperty(CLIENT_LOG_USESLF4J, "false"));\n if (!CLIENT_USE_SLF4J) {\n InternalLoggerFactory.setCurrentLoggerType(InnerLoggerFactory.LOGGER_INNER);\n CLIENT_LOGGER = createLogger(LoggerName.CLIENT_LOGGER_NAME);\n createLogger(LoggerName.COMMON_LOGGER_NAME);\n createLogger(RemotingHelper.ROCKETMQ_REMOTING);\n } else {\n CLIENT_LOGGER = InternalLoggerFactory.getLogger(LoggerName.CLIENT_LOGGER_NAME);\n }\n }\n')),(0,a.yg)("h2",{id:"\u793a\u4f8b"},"\u793a\u4f8b"),(0,a.yg)("p",null,"\u4ee5\u4e0b\u662f\u4e00\u4e2a\u7b80\u5355\u793a\u4f8b"),(0,a.yg)("p",null,"\u5728\u542f\u52a8\u811a\u672c\u4e2d\u6216\u8005IDE\u7684VM options\u4e2d\u6dfb\u52a0\u5982\u4e0b\u7cfb\u7edf\u53c2\u6570: "),(0,a.yg)(l.A,{mdxType:"Tabs"},(0,a.yg)(o.A,{value:"Linux\u793a\u4f8b",label:"Linux\u793a\u4f8b",default:!0,mdxType:"TabItem"},(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre"},"-Drocketmq.client.logRoot=/home/admin/logs -Drocketmq.client.logLevel=WARN -Drocketmq.client.logFileMaxIndex=20 -Drocketmq.client.logFileMaxSize=67108864\n"))),(0,a.yg)(o.A,{value:"windows\u793a\u4f8b",label:"windows\u793a\u4f8b",mdxType:"TabItem"},(0,a.yg)("pre",null,(0,a.yg)("code",{parentName:"pre"},"-Drocketmq.client.logRoot=D:\\logs -Drocketmq.client.logLevel=WARN -Drocketmq.client.logFileMaxIndex=20 -Drocketmq.client.logFileMaxSize=67108864\n")))))}m.isMDXComponent=!0}}]);