{"rsdb":{"rid":"244649","subhead":"","postdate":"0","aid":"168341","fid":"76","uid":"1","topic":"1","content":"
\n
\n \u539f\u6587\u51fa\u5904\uff1a \n Lrwin<\/a>\n <\/div> \n

\u4f7f\u7528slf4j<\/h2> \n
    \n
  1. \u4f7f\u7528\u95e8\u9762\u6a21\u5f0f\u7684\u65e5\u5fd7\u6846\u67b6\uff0c\u6709\u5229\u4e8e\u7ef4\u62a4\u548c\u5404\u4e2a\u7c7b\u7684\u65e5\u5fd7\u5904\u7406\u65b9\u5f0f\u7edf\u4e00\u3002<\/li> \n
  2. \u5b9e\u73b0\u65b9\u5f0f\u7edf\u4e00\u4f7f\u7528: Logback\u6846\u67b6<\/li> \n <\/ol> \n

    \u6253\u65e5\u5fd7\u7684\u6b63\u786e\u65b9\u5f0f<\/h2> \n

    \u4ec0\u4e48\u65f6\u5019\u5e94\u8be5\u6253\u65e5\u5fd7<\/h3> \n
      \n
    1. \u5f53\u4f60\u9047\u5230\u95ee\u9898\u7684\u65f6\u5019\uff0c\u53ea\u80fd\u901a\u8fc7debug\u529f\u80fd\u6765\u786e\u5b9a\u95ee\u9898\uff0c\u4f60\u5e94\u8be5\u8003\u8651\u6253\u65e5\u5fd7\uff0c\u826f\u597d\u7684\u7cfb\u7edf\uff0c\u662f\u53ef\u4ee5\u901a\u8fc7\u65e5\u5fd7\u8fdb\u884c\u95ee\u9898\u5b9a\u4e3a\u7684\u3002<\/li> \n
    2. \u5f53\u4f60\u78b0\u5230if\u2026else \u6216\u8005 switch\u8fd9\u6837\u7684\u5206\u652f\u65f6\uff0c\u8981\u5728\u5206\u652f\u7684\u9996\u884c\u6253\u5370\u65e5\u5fd7\uff0c\u7528\u6765\u786e\u5b9a\u8fdb\u5165\u4e86\u54ea\u4e2a\u5206\u652f<\/li> \n
    3. \u7ecf\u5e38\u4ee5\u529f\u80fd\u4e3a\u6838\u5fc3\u8fdb\u884c\u5f00\u53d1\uff0c\u4f60\u5e94\u8be5\u5728\u63d0\u4ea4\u4ee3\u7801\u524d\uff0c\u53ef\u4ee5\u786e\u5b9a\u901a\u8fc7\u65e5\u5fd7\u53ef\u4ee5\u770b\u5230\u6574\u4e2a\u6d41\u7a0b<\/li> \n <\/ol> \n

      \u57fa\u672c\u683c\u5f0f<\/h3> \n

      \u5fc5\u987b\u4f7f\u7528\u53c2\u6570\u5316\u4fe1\u606f\u7684\u65b9\u5f0f:<\/p> \n

      logger.debug("Processing trade with id:[{}] and symbol : [{}] ", id, symbol);<\/pre> \n 

      \u5bf9\u4e8edebug\u65e5\u5fd7\uff0c\u5fc5\u987b\u5224\u65ad\u662f\u5426\u4e3adebug\u7ea7\u522b\u540e\uff0c\u624d\u8fdb\u884c\u4f7f\u7528:<\/p> \n

      if (logger.isDebugEnabled()) {\r\n    logger.debug("Processing trade with id: " +id + " symbol: " + symbol);\r\n}<\/pre> \n 

      \u4e0d\u8981\u8fdb\u884c\u5b57\u7b26\u4e32\u62fc\u63a5,\u90a3\u6837\u4f1a\u4ea7\u751f\u5f88\u591aString\u5bf9\u8c61\uff0c\u5360\u7528\u7a7a\u95f4\uff0c\u5f71\u54cd\u6027\u80fd\u3002
      \u53cd\u4f8b(\u4e0d\u8981\u8fd9\u4e48\u505a):<\/p> \n

      logger.debug("Processing trade with id: " + id + " symbol: " + symbol);<\/pre> \n 

      \u4f7f\u7528[]\u8fdb\u884c\u53c2\u6570\u53d8\u91cf\u9694\u79bb<\/h3> \n

      \u5982\u6709\u53c2\u6570\u53d8\u91cf\uff0c\u5e94\u8be5\u5199\u6210\u5982\u4e0b\u5199\u6cd5:<\/p> \n

      logger.debug("Processing trade with id:[{}] and symbol : [{}] ", id, symbol);<\/pre> \n 

      \u8fd9\u6837\u7684\u683c\u5f0f\u5199\u6cd5\uff0c\u53ef\u8bfb\u6027\u66f4\u597d\uff0c\u5bf9\u4e8e\u6392\u67e5\u95ee\u9898\u66f4\u6709\u5e2e\u52a9\u3002<\/p> \n

      \u4e0d\u540c\u7ea7\u522b\u7684\u4f7f\u7528<\/h3> \n

      ERROR:<\/h4> \n

      \u57fa\u672c\u6982\u5ff5<\/h5> \n

      \u5f71\u54cd\u5230\u7a0b\u5e8f\u6b63\u5e38\u8fd0\u884c\u3001\u5f53\u524d\u8bf7\u6c42\u6b63\u5e38\u8fd0\u884c\u7684\u5f02\u5e38\u60c5\u51b5:<\/p> \n

        \n
      1. \u6253\u5f00\u914d\u7f6e\u6587\u4ef6\u5931\u8d25<\/li> \n
      2. \u6240\u6709\u7b2c\u4e09\u65b9\u5bf9\u63a5\u7684\u5f02\u5e38(\u5305\u62ec\u7b2c\u4e09\u65b9\u8fd4\u56de\u9519\u8bef\u7801)<\/li> \n
      3. \u6240\u6709\u5f71\u54cd\u529f\u80fd\u4f7f\u7528\u7684\u5f02\u5e38\uff0c\u5305\u62ec:SQLException\u548c\u9664\u4e86\u4e1a\u52a1\u5f02\u5e38\u4e4b\u5916\u7684\u6240\u6709\u5f02\u5e38(RuntimeException\u548cException)<\/li> \n <\/ol> \n

        \u4e0d\u5e94\u8be5\u51fa\u73b0\u7684\u60c5\u51b5:<\/p> \n

          \n
        1. \u6bd4\u5982\u8981\u4f7f\u7528Azure\u4f20\u56fe\u7247\uff0c\u4f46\u662fAzure\u672a\u54cd\u5e94<\/li> \n <\/ol> \n

          \u5982\u679c\u6709Throwable\u4fe1\u606f\uff0c\u9700\u8981\u8bb0\u5f55\u5b8c\u6210\u7684\u5806\u6808\u4fe1\u606f:<\/p> \n

          log.error("\u83b7\u53d6\u7528\u6237[{}]\u7684\u7528\u6237\u4fe1\u606f\u65f6\u51fa\u9519",userName,e);<\/pre> \n 
          \u8bf4\u660e<\/h5> \n
            \n
          1. \u5982\u679c\u8fdb\u884c\u4e86\u629b\u51fa\u5f02\u5e38\u64cd\u4f5c\uff0c\u8bf7\u4e0d\u8981\u8bb0\u5f55error\u65e5\u5fd7\uff0c\u7531\u6700\u7ec8\u5904\u7406\u65b9\u8fdb\u884c\u5904\u7406\uff1a<\/li> \n <\/ol> \n

            \u53cd\u4f8b(\u4e0d\u8981\u8fd9\u4e48\u505a):<\/p> \n

            try{\r\n    ....\r\n}catch(Exception ex){\r\n  String errorMessage=String.format("Error while reading information of user [%s]",userName);\r\n  logger.error(errorMessage,ex);\r\n  throw new UserServiceException(errorMessage,ex);\r\n}<\/pre> \n 

            WARN<\/h4> \n

            \u57fa\u672c\u6982\u5ff5<\/h5> \n

            \u4e0d\u5e94\u8be5\u51fa\u73b0\u4f46\u662f\u4e0d\u5f71\u54cd\u7a0b\u5e8f\u3001\u5f53\u524d\u8bf7\u6c42\u6b63\u5e38\u8fd0\u884c\u7684\u5f02\u5e38\u60c5\u51b5:<\/p> \n

              \n
            1. \u6709\u5bb9\u9519\u673a\u5236\u7684\u65f6\u5019\u51fa\u73b0\u7684\u9519\u8bef\u60c5\u51b5<\/li> \n
            2. \u627e\u4e0d\u5230\u914d\u7f6e\u6587\u4ef6\uff0c\u4f46\u662f\u7cfb\u7edf\u80fd\u81ea\u52a8\u521b\u5efa\u914d\u7f6e\u6587\u4ef6<\/li> \n <\/ol> \n

              \u5373\u5c06\u63a5\u8fd1\u4e34\u754c\u503c\u7684\u65f6\u5019\uff0c\u4f8b\u5982\uff1a<\/p> \n

                \n
              1. \u7f13\u5b58\u6c60\u5360\u7528\u8fbe\u5230\u8b66\u544a\u7ebf<\/li> \n <\/ol> \n

                \u4e1a\u52a1\u5f02\u5e38\u7684\u8bb0\u5f55,\u6bd4\u5982:<\/p> \n

                  \n
                1. \u5f53\u63a5\u53e3\u629b\u51fa\u4e1a\u52a1\u5f02\u5e38\u65f6\uff0c\u5e94\u8be5\u8bb0\u5f55\u6b64\u5f02\u5e38<\/li> \n <\/ol> \n

                  INFO:<\/h4> \n

                  \u57fa\u672c\u6982\u5ff5<\/h5> \n

                  \u7cfb\u7edf\u8fd0\u884c\u4fe1\u606f<\/p> \n

                    \n
                  1. Service\u65b9\u6cd5\u4e2d\u5bf9\u4e8e\u7cfb\u7edf\/\u4e1a\u52a1\u72b6\u6001\u7684\u53d8\u66f4<\/li> \n
                  2. \u4e3b\u8981\u903b\u8f91\u4e2d\u7684\u5206\u6b65\u9aa4<\/li> \n <\/ol> \n

                    \u5916\u90e8\u63a5\u53e3\u90e8\u5206<\/p> \n

                      \n
                    1. \u5ba2\u6237\u7aef\u8bf7\u6c42\u53c2\u6570(REST\/WS)<\/li> \n
                    2. \u8c03\u7528\u7b2c\u4e09\u65b9\u65f6\u7684\u8c03\u7528\u53c2\u6570\u548c\u8c03\u7528\u7ed3\u679c<\/li> \n <\/ol> \n
                      \u8bf4\u660e<\/h5> \n
                        \n
                      1. \u5e76\u4e0d\u662f\u6240\u6709\u7684service\u90fd\u8fdb\u884c\u51fa\u5165\u53e3\u6253\u70b9\u8bb0\u5f55,\u5355\u4e00\u3001\u7b80\u5355service\u662f\u6ca1\u6709\u610f\u4e49\u7684(job\u9664\u5916,job\u9700\u8981\u8bb0\u5f55\u5f00\u59cb\u548c\u7ed3\u675f,)\u3002
                        \u53cd\u4f8b(\u4e0d\u8981\u8fd9\u4e48\u505a):

                        <\/p>

                        public List listByBaseType(Integer baseTypeId) {\r\n\r\n    log.info("\u5f00\u59cb\u67e5\u8be2\u57fa\u5730");\r\nBaseExample ex=new BaseExample();\r\nBaseExample.Criteria ctr = ex.createCriteria();\r\nctr.andIsDeleteEqualTo(IsDelete.USE.getValue());\r\nOptionals.doIfPresent(baseTypeId, ctr::andBaseTypeIdEqualTo);\r\n    log.info("\u67e5\u8be2\u57fa\u5730\u7ed3\u675f");\r\nreturn baseRepository.selectByExample(ex);\r\n}<\/pre> <\/li> \n  
                      2. \u5bf9\u4e8e\u590d\u6742\u7684\u4e1a\u52a1\u903b\u8f91\uff0c\u9700\u8981\u8fdb\u884c\u65e5\u5fd7\u6253\u70b9\uff0c\u4ee5\u53ca\u57cb\u70b9\u8bb0\u5f55\uff0c\u6bd4\u5982\u7535\u5546\u7cfb\u7edf\u4e2d\u7684\u4e0b\u8ba2\u5355\u903b\u8f91\uff0c\u4ee5\u53caOrderAction\u64cd\u4f5c(\u4e1a\u52a1\u72b6\u6001\u53d8\u66f4)\u3002<\/li> \n
                      3. \u5bf9\u4e8e\u6574\u4e2a\u7cfb\u7edf\u7684\u63d0\u4f9b\u51fa\u7684\u63a5\u53e3(REST\/WS)\uff0c\u4f7f\u7528info\u8bb0\u5f55\u5165\u53c2<\/li> \n
                      4. \u5982\u679c\u6240\u6709\u7684service\u4e3aSOA\u67b6\u6784\uff0c\u90a3\u4e48\u53ef\u4ee5\u770b\u6210\u662f\u4e00\u4e2a\u5916\u90e8\u63a5\u53e3\u63d0\u4f9b\u65b9\uff0c\u90a3\u4e48\u5fc5\u987b\u8bb0\u5f55\u5165\u53c2\u3002<\/li> \n
                      5. \u8c03\u7528\u5176\u4ed6\u7b2c\u4e09\u65b9\u670d\u52a1\u65f6\uff0c\u6240\u6709\u7684\u51fa\u53c2\u548c\u5165\u53c2\u662f\u5fc5\u987b\u8981\u8bb0\u5f55\u7684(\u56e0\u4e3a\u4f60\u5f88\u96be\u8ffd\u6eaf\u7b2c\u4e09\u65b9\u6a21\u5757\u53d1\u751f\u7684\u95ee\u9898)<\/li> \n <\/ol> \n

                        DEBUG<\/h4> \n

                        \u57fa\u672c\u6982\u5ff5<\/h5> \n
                          \n
                        1. \u53ef\u4ee5\u586b\u5199\u6240\u6709\u7684\u60f3\u77e5\u9053\u7684\u76f8\u5173\u4fe1\u606f(\u4f46\u4e0d\u4ee3\u8868\u53ef\u4ee5\u968f\u4fbf\u5199\uff0cdebug\u4fe1\u606f\u8981\u6709\u610f\u4e49,\u6700\u597d\u6709\u76f8\u5173\u53c2\u6570)<\/li> \n
                        2. \u751f\u4ea7\u73af\u5883\u9700\u8981\u5173\u95edDEBUG\u4fe1\u606f<\/li> \n
                        3. \u5982\u679c\u5728\u751f\u4ea7\u60c5\u51b5\u4e0b\u9700\u8981\u5f00\u542fDEBUG,\u9700\u8981\u4f7f\u7528\u5f00\u5173\u8fdb\u884c\u7ba1\u7406\uff0c\u4e0d\u80fd\u4e00\u76f4\u5f00\u542f\u3002<\/li> \n <\/ol> \n
                          \u8bf4\u660e<\/h5> \n

                          \u5982\u679c\u4ee3\u7801\u4e2d\u51fa\u73b0\u4ee5\u4e0b\u4ee3\u7801\uff0c\u53ef\u4ee5\u8fdb\u884c\u4f18\u5316:<\/p> \n

                          \/\/1. \u83b7\u53d6\u7528\u6237\u57fa\u672c\u85aa\u8d44\r\n\r\n\/\/2. \u83b7\u53d6\u7528\u6237\u4f11\u5047\u60c5\u51b5\r\n\r\n\/\/3. \u8ba1\u7b97\u7528\u6237\u5e94\u5f97\u85aa\u8d44<\/pre> \n 

                          \u4f18\u5316\u540e\u7684\u4ee3\u7801:<\/p> \n

                          logger.debug("\u5f00\u59cb\u83b7\u53d6\u5458\u5de5[{}] [{}]\u5e74\u57fa\u672c\u85aa\u8d44",employee,year);\r\n\r\nlogger.debug("\u83b7\u53d6\u5458\u5de5[{}] [{}]\u5e74\u7684\u57fa\u672c\u85aa\u8d44\u4e3a[{}]",employee,year,basicSalary);\r\nlogger.debug("\u5f00\u59cb\u83b7\u53d6\u5458\u5de5[{}] [{}]\u5e74[{}]\u6708\u4f11\u5047\u60c5\u51b5",employee,year,month);\r\n\r\nlogger.debug("\u5458\u5de5[{}][{}]\u5e74[{}]\u6708\u5e74\u5047\/\u75c5\u5047\/\u4e8b\u5047\u4e3a[{}]\/[{}]\/[{}]",employee,year,month,annualLeaveDays,sickLeaveDays,noPayLeaveDays);\r\nlogger.debug("\u5f00\u59cb\u8ba1\u7b97\u5458\u5de5[{}][{}]\u5e74[{}]\u6708\u5e94\u5f97\u85aa\u8d44",employee,year,month);\r\n\r\nlogger.debug("\u5458\u5de5[{}] [{}]\u5e74[{}]\u6708\u5e94\u5f97\u85aa\u8d44\u4e3a[{}]",employee,year,month,actualSalary);<\/pre> \n 

                          TRACE<\/h4> \n

                          \u57fa\u672c\u6982\u5ff5<\/h5> \n

                          \u7279\u522b\u8be6\u7ec6\u7684\u7cfb\u7edf\u8fd0\u884c\u5b8c\u6210\u4fe1\u606f\uff0c\u4e1a\u52a1\u4ee3\u7801\u4e2d\uff0c\u4e0d\u8981\u4f7f\u7528.(\u9664\u975e\u6709\u7279\u6b8a\u7528\u610f\uff0c\u5426\u5219\u8bf7\u4f7f\u7528DEBUG\u7ea7\u522b\u66ff\u4ee3)<\/p> \n

                          \u89c4\u8303\u793a\u4f8b\u8bf4\u660e<\/h3> \n
                          @Override\r\n@Transactional\r\npublic void createUserAndBindMobile(@NotBlank String mobile, @NotNull User user) t","orderid":"0","title":"\u6b63\u786e\u7684\u6253\u65e5\u5fd7\u59ff\u52bf(\u4e00)","smalltitle":"","mid":"0","fname":"JAVA","special_id":"0","bak_id":"0","info":"0","hits":"356","pages":"2","comments":"0","posttime":"2018-02-22 14:32:41","list":"1519281161","username":"admin","author":"","copyfrom":"","copyfromurl":"","titlecolor":"","fonttype":"0","titleicon":"0","picurl":"https:\/\/www.cppentry.com\/upload_files\/","ispic":"0","yz":"1","yzer":"","yztime":"0","levels":"0","levelstime":"0","keywords":"\u6b63\u786e<\/A> \u65e5\u5fd7<\/A> \u59ff\u52bf<\/A>","jumpurl":"","iframeurl":"","style":"","template":"a:3:{s:4:\"head\";s:0:\"\";s:4:\"foot\";s:0:\"\";s:8:\"bencandy\";s:0:\"\";}","target":"0","ip":"14.20.29.21","lastfid":"0","money":"0","buyuser":"","passwd":"","allowdown":"","allowview":"","editer":"","edittime":"0","begintime":"0","endtime":"0","description":"\u6b63\u786e\u7684\u6253\u65e5\u5fd7\u59ff\u52bf","lastview":"1695359672","digg_num":"0","digg_time":"0","forbidcomment":"0","ifvote":"0","heart":"","htmlname":"","city_id":"0"},"page":"1"}