<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-204  評論-90  文章-8  trackbacks-0
      2013年11月20日
    此問題是由于升級 macos sonoma 14.2.1 引起的
    解決辦法,重新安裝xcode  
    rm -rf /Library/Developer/CommandLineTools
    xcode
    -select --install
    posted @ 2024-02-04 13:57 一凡 閱讀(52) | 評論 (0)編輯 收藏
    # Springboot整合activiti
    源代碼:https://gitee.com/yifan88899/acttest

    ## 版本說明
    - springboot 2.4.2
    - activiti 7.1.0.M6
    - mysql 8.0.28
    ## 插件安裝
    - Activiti BPMN visualizer
    ## Bpmn流程圖位置
    - 流程圖xmlpng需放在resources/processes
    ## Test
    - Test Case 都可執行,包括:
    - 流程查詢
    - 流程部署
    - 流程啟動
    - 流程拾取、完成操作
    ## Mysql
    - 需要啟動Mysql8
    - 數據庫名Activiti7
    - activiti會版建表

    posted @ 2023-11-10 15:56 一凡 閱讀(97) | 評論 (0)編輯 收藏
    1、打開my.cnf 加入 skip-grant-tables
    2、mysql.service stop && mysql.service start
    3、清空root密碼 并 退出
        update mysql.user set authentication_string='' where user='root';  
    4、mysql.service stop && mysql.service start
    5、mysql -root   免密登錄并修改root密碼
        alter user 'root'@'%' identified by 'pass$123';
        alter user 'root'@'localhost' identified by 'pass$123';

    確定是否支持遠程登錄,host中有%的記錄即支持
    select host, user, authentication_string, plugin from user;
    posted @ 2021-08-05 18:06 一凡 閱讀(203) | 評論 (0)編輯 收藏

    64e696 綠色
    5a97ff 藍色
    ffdb5a 黃色
    ff8b64 橙色
    ff5a65 紅色
    e00b5d 粉紅
    666666 深灰
    3cc7f5 淺藍
    f5863c 淺橙
    b00072 枚紅
    674ea7 紫色
    999999 灰色
    posted @ 2021-06-22 17:46 一凡 閱讀(84) | 評論 (0)編輯 收藏
    #!/usr/bin/expect
    ####################
    set pass xxxx
    set user yyyy
    ####################
    spawn ssh -p 35000 -o StrictHostKeyChecking=no "${user}@xgrelay.xxxx.com"
    expect {
      -re ".*Dkey.*" { gets stdin dkey; send "$dkey\r"; exp_continue}
      -re "Option>:"  { send "1\r" ;}
      -re "Password>:" { send "$pass\r" ; exp_continue }
      -re "password:" { send "$pass\r" ; exp_continue }
    }
    posted @ 2021-01-18 11:35 一凡 閱讀(163) | 評論 (0)編輯 收藏
    -- data export csv   其中 $1=$1 如果不加指定分隔符不生效
    mysql -uadmin -ptest -h127.0.0.1 -P3306 -e "select * from test where create_time > unix_timestamp('2020-09-10 00:00:00'and status = 99| awk '{OFS=","}{$1=$1;print $0}'

    #csv中文轉碼
    tmpfn="exempt-update-3.30.csv";iconv -c -s -f UTF-8 -t GBK $tmpfn > /tmp/$tmpfn && mv /tmp/$tmpfn .
    posted @ 2020-09-10 22:08 一凡 閱讀(187) | 評論 (0)編輯 收藏
    #!/bin/bash

    for f in "$@"do
        if [ -f "$f" ]; then
            iconv -s -c -f UTF8 -t GBK "$f" > /tmp/$f.tmp
            mv /tmp/$f.tmp "$f"
        fi
    done
    posted @ 2020-04-20 10:03 一凡 閱讀(186) | 評論 (0)編輯 收藏
    # -*- coding: utf-8 -*-
    #
    !/usr/bin/python

    import re
    import io
    import sys

    # obj = re.compile(r'(?P<ip>.*?)- - \[(?P<time>.*?)\] "(?P<request>.*?)" (?P<status>.*?) (?P<bytes>.*?) "(?P<referer>.*?)" "(?P<ua>.*?)"')
    #
     example:xxxx"id":2640914,"orderId":144115188137125591xxxx"state":10xxxxx"
    # 日志整行都需要匹配,需要用的用具體正則匹配,如(\d{7}),不需要的用(.*)匹配,總之所有需要或不需要部分都用()括起來
    obj = re.compile(r'(.*"id":)(\d{7})(.*"orderId":)(\d{18})(.*"state":)(\d{2})(.*)')

    def load_log(path):
    # 讀取文件
        with io.open(path, mode="r", encoding="utf-8") as f:
            for line in f:
                line = line.strip()
                parse(line)

    def stdin():
    # 讀取管道輸入
        for line in sys.stdin:
            parse(line)

    def parse(line):
    # 解析單行nginx日志
        try:
            result = obj.match(line)
            print(result.group(2,4,6))
        except:
            pass

    if __name__ == '__main__':
        # load_log("/tmp/227.log")
        stdin()
    posted @ 2020-02-29 02:10 一凡 閱讀(295) | 評論 (0)編輯 收藏
    1. 新增中間件cors
    2. func Cors() gin.HandlerFunc {
      return func(c *gin.Context) {
      method := c.Request.Method

      c.Header("Access-Control-Allow-Origin", "*") //必選
           c.Header("Access-Control-Allow-Headers", "*") //可選 如果request有header, 必選
           //c.Header("Access-Control-Allow-Credentials", "true") //可選
      //c.Header("Access-Control-Allow-Methods", "*") //可選
      //c.Header("Access-Control-Expose-Headers", "*") //可選

      //放行所有OPTIONS方法
      if method == "OPTIONS" {
      c.AbortWithStatus(http.StatusOK)
      }
      // 處理請求
      c.Next()
      }
      }
    3. 在router里增加cors,必須在group之前,全局設置
      r.Use(gin.Logger(), gin.Recovery(), cors.Cors())
    4. 測試代碼,header設置不能多于cors設置
      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <title>Title</title>
      </head>
      <link type="test/css" href="css/style.css" rel="stylesheet">
      <script type="text/javascript" src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
      <script type="text/javascript">
      $(function(){
      $("#cors").click(
      function(){
      $.ajax({
      headers:{
      "Content-Type":"application/json;charset=UTF-8",
      "Access":"adsad",
      "Access-Token":"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InRlc3QiLCJwYXNzd29yZCI6InRlc3QxMjM0NTYiLCJleHAiOjE1NzczMzY3MTIsImlzcyI6Imdpbi1ibG9nIn0.wMlQXqZO2V0LR-FIgDh45LWI0OYMYi6an_NvRmF0Nug"
      },
      url:"http://127.0.0.1:8000/api/v1/articles",
      success:function(data){
      console.log("start");
      console.log(data);
      }
      })
      });
      });
      </script>
      <body>
      <input type="button" id="cors" value="core跨域測試">
      </body>
      </html>
    5. 請求的headers數量、名稱與cors里的設置需要嚴格對應,不然報錯如下
      Access to XMLHttpRequest at 'http://127.0.0.1:8000/api/v1/articles' from origin 'http://localhost:9999' has been blocked by CORS policy: Request header field access is not allowed by Access-Control-Allow-Headers in preflight response.
    posted @ 2019-12-26 11:17 一凡 閱讀(326) | 評論 (0)編輯 收藏
    1、在main函數中增加全局配置,其中@name就是你確定的鑒權參數名,我的是token,    @in header 說明參數放在header,你的鑒權代碼需要從header中獲取

    // @title gin-blog API
    // @version 0.0.1
    // @description This is a gin blog example
    // @securityDefinitions.apikey ApiKeyAuth
    // @in header
    // @name token
    // @BasePath /

    2、在具體的handler里添加如下注釋,此處的ApiKeyAuth和main中的apike對應,切記不要修改
    // @Security ApiKeyAuth

    3、swagger頁面如下:


    4、添加token后,后續所有有鑒權接口的header里自動攜帶token
    posted @ 2019-12-23 16:08 一凡 閱讀(1992) | 評論 (0)編輯 收藏
    posted @ 2019-11-19 16:41 一凡 閱讀(146) | 評論 (0)編輯 收藏
     處理1W條復雜json數據性能對比

    1. golang

      ./go_extract_json  0.95s user 0.12s system 99% cpu 1.081 total    
    2. shell
      bash segment.sh  0.64s user 0.07s system 101% cpu 0.695 total
    3. perl
      perl extract.pl  39.57s user 0.54s system 98% cpu 40.579 total
    posted @ 2019-09-20 18:13 一凡 閱讀(221) | 評論 (0)編輯 收藏
    1.  Invalid bound statement (not found)
      在接口名稱及方法名稱對應OK的情況下,在application.properties中添加:
    mybatis.mapperLocations=classpath:mapper/*Mapper.xml   
    mybatis.typeAliasesPackage=com.willpower.entity
    posted @ 2019-04-03 21:41 一凡 閱讀(130) | 評論 (0)編輯 收藏
    推薦:
    https://github.com/wming3/.vimToIDE
    posted @ 2017-05-08 16:33 一凡 閱讀(224) | 評論 (0)編輯 收藏

    http://www.iteye.com/news/32170

    Guice OKHttp Retrofit 
    posted @ 2017-03-02 17:36 一凡 閱讀(135) | 評論 (0)編輯 收藏
    http://www.iteye.com/news/32119
    posted @ 2017-02-10 18:57 一凡 閱讀(142) | 評論 (0)編輯 收藏
    http://www.iteye.com/news/31877
    posted @ 2016-10-11 15:26 一凡 閱讀(168) | 評論 (0)編輯 收藏
     //mysql
     mysql -uroot -proot -h127.0.0.1 testdb -e " select a, b, c, d from t_test where a='xxxx'" | sed 's/\t/","/g;s/^/"/;s/$/"/;s/\n//g' > /tmp/xxxxx.csv
    posted @ 2015-01-22 18:55 一凡 閱讀(354) | 評論 (0)編輯 收藏

        http://www.oracle.com/

        wget下載方法:
        1、在打開瀏覽器的開發者工具
        2、在network里找到類似http://download.oracle.com/otn/java/jdk/6u45-b06/jdk-6u45-linux-x64.bin?AuthParam=1416809306_8aff16bf46c832f44260abcc951c58ea


    wget http://download.oracle.com/otn/java/jdk/6u45-b06/jdk-6u45-linux-x64.bin\?AuthParam=1416809306_8aff16bf46c832f44260abcc951c58ea
    注意:紅色,由于?是通配符,需要轉義一下。
    posted @ 2014-11-24 14:09 一凡 閱讀(226) | 評論 (0)編輯 收藏
    set hlsearch                  "高亮度反白
    set backspace=2               
    "可隨時用倒退鍵刪除
    set autoindent                 "自動縮排
    set ruler                      
    "可顯示最后一行的狀態
    set showmode                 "左下角那一行的狀態
    set nu                        
    "可以在每一行的最前面顯示行號
    set bg=dark                   "顯示不同的底色色調
    syntax on                     
    "進行語法檢驗,顏色顯示
    set wrap                      "自動折行
    set shiftwidth=4
    set tabstop=4
    set softtabstop=4
    set expandtab                  
    "將tab替換為相應數量空格
    set smartindent
    "phpcomplete
    filetype plugin on
    autocmd FileType php set omnifunc=phpcomplete#CompletePHP
    "php-doc
    source /home/qiaoy/sf/php-doc.vim
    inoremap <C-P> <ESC>:call PhpDocSingle()<CR>i
    nnoremap <C-P> :call PhpDocSingle()<CR>
    vnoremap <C-P> :call PhpDocRange()<CR>

    "neocomplcache
    if &term==
    "xterm"
        set t_Co=8
        set t_Sb=^[[4%dm
        set t_Sf=^[[3%dm
    endif
    let g:neocomplcache_enable_at_startup = 1

    "autoload .vimrc
    autocmd! bufwritepost .vimrc source %
    posted @ 2014-09-17 14:27 一凡 閱讀(280) | 評論 (0)編輯 收藏
    #!/bin/bash
     for((i=0; i<100; i++));do
         curl -i -H "xxx -H "Accept:application/json" -H "Content-Type:application/json" -sd '{"xxx": 563,"xxx": 1,"xxx": 0,"xxx": "{\"xxx\":0,\"xxx\":\"xxx\"}"}' -H "Cookie: JSESSIONID=4F8F7834CEABB668BE84BD3B61AEBE9E" http://test.com;
    done
    posted @ 2014-08-20 13:23 一凡 閱讀(306) | 評論 (0)編輯 收藏
    pasting

    log4j.properties 使用
    一.參數意義說明
    輸出級別的種類
    ERROR、WARN、INFO、DEBUG
    ERROR 為嚴重錯誤 主要是程序的錯誤
    WARN 為一般警告,比如session丟失
    INFO 為一般要顯示的信息,比如登錄登出
    DEBUG 為程序的調試信息
    配置日志信息輸出目的地
    log4j.appender.appenderName = fully.qualified.name.of.appender.class
    1.org.apache.log4j.ConsoleAppender(控制臺)
    2.org.apache.log4j.FileAppender(文件)
    3.org.apache.log4j.DailyRollingFileAppender(每天產生一個日志文件)
    4.org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件)
    5.org.apache.log4j.WriterAppender(將日志信息以流格式發送到任意指定的地方)
    配置日志信息的格式
    log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
    1.org.apache.log4j.HTMLLayout(以HTML表格形式布局),
    2.org.apache.log4j.PatternLayout(可以靈活地指定布局模式),
    3.org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串),
    4.org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息)
    控制臺選項
    Threshold=DEBUG:指定日志消息的輸出最低層次。
    ImmediateFlush=true:默認值是true,意謂著所有的消息都會被立即輸出。
    Target=System.err:默認情況下是:System.out,指定輸出控制臺
    FileAppender 選項
    Threshold=DEBUF:指定日志消息的輸出最低層次。
    ImmediateFlush=true:默認值是true,意謂著所有的消息都會被立即輸出。
    File=mylog.txt:指定消息輸出到mylog.txt文件。
    Append=false:默認值是true,即將消息增加到指定文件中,false指將消息覆蓋指定的文件內容。
    RollingFileAppender 選項
    Threshold=DEBUG:指定日志消息的輸出最低層次。
    ImmediateFlush=true:默認值是true,意謂著所有的消息都會被立即輸出。
    File=mylog.txt:指定消息輸出到mylog.txt文件。
    Append=false:默認值是true,即將消息增加到指定文件中,false指將消息覆蓋指定的文件內容。
    MaxFileSize=100KB: 后綴可以是KB, MB 或者是 GB. 在日志文件到達該大小時,將會自動滾動,即將原來的內容移到mylog.log.1文件。
    MaxBackupIndex=2:指定可以產生的滾動文件的最大數。
    log4j.appender.A1.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n
    日志信息格式中幾個符號所代表的含義:
     -X號: X信息輸出時左對齊;
     %p: 輸出日志信息優先級,即DEBUG,INFO,WARN,ERROR,FATAL,
     %d: 輸出日志時間點的日期或時間,默認格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},輸出類似:2002年10月18日 22:10:28,921
     %r: 輸出自應用啟動到輸出該log信息耗費的毫秒數
     %c: 輸出日志信息所屬的類目,通常就是所在類的全名
     %t: 輸出產生該日志事件的線程名
     %l: 輸出日志事件的發生位置,相當于%C.%M(%F:%L)的組合,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main (TestLog4.java:10)
     %x: 輸出和當前線程相關聯的NDC(嵌套診斷環境),尤其用到像java servlets這樣的多客戶多線程的應用中。
     %%: 輸出一個"%"字符
     %F: 輸出日志消息產生時所在的文件名稱
     %L: 輸出代碼中的行號
     %m: 輸出代碼中指定的消息,產生的日志具體信息
     %n: 輸出一個回車換行符,Windows平臺為"/r/n",Unix平臺為"/n"輸出日志信息換行
     可以在%與模式字符之間加上修飾符來控制其最小寬度、最大寬度、和文本的對齊方式。如:
     1)%20c:指定輸出category的名稱,最小的寬度是20,如果category的名稱小于20的話,默認的情況下右對齊。
     2)%-20c:指定輸出category的名稱,最小的寬度是20,如果category的名稱小于20的話,"-"號指定左對齊。
     3)%.30c:指定輸出category的名稱,最大的寬度是30,如果category的名稱大于30的話,就會將左邊多出的字符截掉,但小于30的話也不會有空格。
     4)%20.30c:如果category的名稱小于20就補空格,并且右對齊,如果其名稱長于30字符,就從左邊較遠輸出的字符截掉。
    二.文件配置Sample1
    log4j.rootLogger=DEBUG,A1,R
    #log4j.rootLogger=INFO,A1,R
    # ConsoleAppender 輸出
    log4j.appender.A1=org.apache.log4j.ConsoleAppender
    log4j.appender.A1.layout=org.apache.log4j.PatternLayout
    log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n
    # File 輸出 一天一個文件,輸出路徑可以定制,一般在根路徑下
    log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
    log4j.appender.R.File=blog_log.txt
    log4j.appender.R.MaxFileSize=500KB
    log4j.appender.R.MaxBackupIndex=10
    log4j.appender.R.layout=org.apache.log4j.PatternLayout
    log4j.appender.R.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%c] [%p] - %m%n
    文件配置Sample2
    下面給出的Log4J配置文件實現了輸出到控制臺,文件,回滾文件,發送日志郵件,輸出到數據庫日志表,自定義標簽等全套功能。
    log4j.rootLogger=DEBUG,CONSOLE,A1,im 
    #DEBUG,CONSOLE,FILE,ROLLING_FILE,MAIL,DATABASE
    log4j.addivity.org.apache=true
    ################### 
    # Console Appender 
    ################### 
    log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender 
    log4j.appender.Threshold=DEBUG 
    log4j.appender.CONSOLE.Target=System.out 
    log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout 
    log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n 
    #log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n
    ##################### 
    # File Appender 
    ##################### 
    log4j.appender.FILE=org.apache.log4j.FileAppender 
    log4j.appender.FILE.File=file.log 
    log4j.appender.FILE.Append=false 
    log4j.appender.FILE.layout=org.apache.log4j.PatternLayout 
    log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n 
    # Use this layout for LogFactor 5 analysis
    ######################## 
    # Rolling File 
    ######################## 
    log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender 
    log4j.appender.ROLLING_FILE.Threshold=ERROR 
    log4j.appender.ROLLING_FILE.File=rolling.log 
    log4j.appender.ROLLING_FILE.Append=true 
    log4j.appender.ROLLING_FILE.MaxFileSize=10KB 
    log4j.appender.ROLLING_FILE.MaxBackupIndex=1 
    log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout 
    log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
    #################### 
    # Socket Appender 
    #################### 
    log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender 
    log4j.appender.SOCKET.RemoteHost=localhost 
    log4j.appender.SOCKET.Port=5001 
    log4j.appender.SOCKET.LocationInfo=true 
    # Set up for Log Facter 5 
    log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout 
    log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n
    ######################## 
    # Log Factor 5 Appender 
    ######################## 
    log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender 
    log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000
    ######################## 
    # SMTP Appender 
    ####################### 
    log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender 
    log4j.appender.MAIL.Threshold=FATAL 
    log4j.appender.MAIL.BufferSize=10 
    log4j.appender.MAIL.From=chenyl@yeqiangwei.com
    log4j.appender.MAIL.SMTPHost=mail.hollycrm.com 
    log4j.appender.MAIL.Subject=Log4J Message 
    log4j.appender.MAIL.To=chenyl@yeqiangwei.com
    log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout 
    log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
    ######################## 
    # JDBC Appender 
    ####################### 
    log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender 
    log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test 
    log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver 
    log4j.appender.DATABASE.user=root 
    log4j.appender.DATABASE.password= 
    log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n') 
    log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout 
    log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
    log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender 
    log4j.appender.A1.File=SampleMessages.log4j 
    log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j' 
    log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout
    ################### 
    #自定義Appender 
    ################### 
    log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender
    log4j.appender.im.host = mail.cybercorlin.net 
    log4j.appender.im.username = username 
    log4j.appender.im.password = password 
    log4j.appender.im.recipient = corlin@yeqiangwei.com
    log4j.appender.im.layout=org.apache.log4j.PatternLayout 
    log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
    三.高級使用
    實驗目的:
     1.把FATAL級錯誤寫入2000NT日志
     2. WARN,ERROR,FATAL級錯誤發送email通知管理員
     3.其他級別的錯誤直接在后臺輸出
    實驗步驟:
     輸出到2000NT日志
     1.把Log4j壓縮包里的NTEventLogAppender.dll拷到WINNT/SYSTEM32目錄下
     2.寫配置文件log4j.properties
    # 在2000系統日志輸出
     log4j.logger.NTlog=FATAL, A8
     # APPENDER A8
     log4j.appender.A8=org.apache.log4j.nt.NTEventLogAppender
     log4j.appender.A8.Source=JavaTest
     log4j.appender.A8.layout=org.apache.log4j.PatternLayout
     log4j.appender.A8.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
    3.調用代碼:
     Logger logger2 = Logger.getLogger("NTlog"); //要和配置文件中設置的名字相同
     logger2.debug("debug!!!");
     logger2.info("info!!!");
     logger2.warn("warn!!!");
     logger2.error("error!!!");
     //只有這個錯誤才會寫入2000日志
     logger2.fatal("fatal!!!");
    發送email通知管理員:
     1. 首先下載JavaMail和JAF, 
      http://java.sun.com/j2ee/ja/javamail/index.html
      http://java.sun.com/beans/glasgow/jaf.html
     在項目中引用mail.jar和activation.jar。
     2. 寫配置文件
     # 將日志發送到email
     log4j.logger.MailLog=WARN,A5
     #  APPENDER A5
     log4j.appender.A5=org.apache.log4j.net.SMTPAppender
     log4j.appender.A5.BufferSize=5
     log4j.appender.A5.To=chunjie@yeqiangwei.com
     log4j.appender.A5.From=error@yeqiangwei.com
     log4j.appender.A5.Subject=ErrorLog
     log4j.appender.A5.SMTPHost=smtp.263.net
     log4j.appender.A5.layout=org.apache.log4j.PatternLayout
     log4j.appender.A5.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
     3.調用代碼:
     //把日志發送到mail
     Logger logger3 = Logger.getLogger("MailLog");
     logger3.warn("warn!!!");
     logger3.error("error!!!");
     logger3.fatal("fatal!!!");
    在后臺輸出所有類別的錯誤:
     1. 寫配置文件
     # 在后臺輸出
     log4j.logger.console=DEBUG, A1
     # APPENDER A1
     log4j.appender.A1=org.apache.log4j.ConsoleAppender
     log4j.appender.A1.layout=org.apache.log4j.PatternLayout
     log4j.appender.A1.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
     2.調用代碼
     Logger logger1 = Logger.getLogger("console");
     logger1.debug("debug!!!");
     logger1.info("info!!!");
     logger1.warn("warn!!!");
     logger1.error("error!!!");
     logger1.fatal("fatal!!!");
    --------------------------------------------------------------------
     全部配置文件:log4j.properties
     # 在后臺輸出
     log4j.logger.console=DEBUG, A1
     # APPENDER A1
     log4j.appender.A1=org.apache.log4j.ConsoleAppender
     log4j.appender.A1.layout=org.apache.log4j.PatternLayout
     log4j.appender.A1.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
    # 在2000系統日志輸出
     log4j.logger.NTlog=FATAL, A8
     # APPENDER A8
     log4j.appender.A8=org.apache.log4j.nt.NTEventLogAppender
     log4j.appender.A8.Source=JavaTest
     log4j.appender.A8.layout=org.apache.log4j.PatternLayout
     log4j.appender.A8.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
    # 將日志發送到email
     log4j.logger.MailLog=WARN,A5
     #  APPENDER A5
     log4j.appender.A5=org.apache.log4j.net.SMTPAppender
     log4j.appender.A5.BufferSize=5
     log4j.appender.A5.To=chunjie@yeqiangwei.com
     log4j.appender.A5.From=error@yeqiangwei.com
     log4j.appender.A5.Subject=ErrorLog
     log4j.appender.A5.SMTPHost=smtp.263.net
     log4j.appender.A5.layout=org.apache.log4j.PatternLayout
     log4j.appender.A5.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
    全部代碼:Log4jTest.java
      
    /* 
      * 創建日期 2003-11-13 
      
    */ 
     package edu.bcu.Bean; 
     import org.apache.log4j.*; 
     //import org.apache.log4j.nt.*; 
     
    //import org.apache.log4j.net.*; 
     /** 
      * 
    @author yanxu 
      
    */ 
     public class Log4jTest 
     { 
      public static void main(String args[]) 
      { 
       PropertyConfigurator.configure("log4j.properties"); 
       //在后臺輸出 
       Logger logger1 = Logger.getLogger("console"); 
       logger1.debug("debug!!!"); 
       logger1.info("info!!!"); 
       logger1.warn("warn!!!"); 
       logger1.error("error!!!"); 
       logger1.fatal("fatal!!!");
    //在NT系統日志輸出 
       Logger logger2 = Logger.getLogger("NTlog"); 
       //NTEventLogAppender nla = new NTEventLogAppender(); 
       logger2.debug("debug!!!"); 
       logger2.info("info!!!"); 
       logger2.warn("warn!!!"); 
       logger2.error("error!!!"); 
       //只有這個錯誤才會寫入2000日志 
       logger2.fatal("fatal!!!");
    //把日志發送到mail 
       Logger logger3 = Logger.getLogger("MailLog"); 
       //SMTPAppender sa = new SMTPAppender(); 
       logger3.warn("warn!!!"); 
       logger3.error("error!!!"); 
       logger3.fatal("fatal!!!"); 
      } 
     }
    posted @ 2014-07-17 11:10 一凡 閱讀(204) | 評論 (0)編輯 收藏
    mac :   lsof -i:8080

    linux : netstat -anltp | grep 8080
    posted @ 2014-07-15 14:20 一凡 閱讀(5464) | 評論 (1)編輯 收藏
    openssl rand 16 -base64
    posted @ 2014-06-16 16:48 一凡 閱讀(251) | 評論 (0)編輯 收藏
    打開多個文件:
    一、vim還沒有啟動的時候:
    1.在終端里輸入 
    vim file1 file2 ... filen便可以打開所有想要打開的文件
    2.vim已經啟動
    輸入
    :e file
    可以再打開一個文件,并且此時vim里會顯示出file文件的內容。
    3.同時顯示多個文件:
    :sp         //水平切分窗口
    :vsplit     //垂直切分窗口
    二、在文件之間切換:
    1.文件間切換
    Ctrl+6  //兩文件間的切換
    :bn      //下一個文件
    :bp      //上一個文件
    :ls       //列出打開的文件,帶編號
    :b1~n  //切換至第n個文件
    對于用(v)split在多個窗格中打開的文件,這種方法只會在當前窗格中切換不同的文件。
    2.在窗格間切換的方法
    Ctrl+w+方向鍵——切換到前/下/上/后一個窗格
    Ctrl+w+h/j/k/l ——同上
    Ctrl+ww——依次向后切換到下一個窗格中
    posted @ 2014-02-19 18:34 一凡 閱讀(33874) | 評論 (2)編輯 收藏
    find . ! -wholename '*.svn*' ! -wholename '*template_c*' -type f -exec grep -H test {} --color \;
    posted @ 2014-02-18 17:19 一凡 閱讀(325) | 評論 (0)編輯 收藏
    curl -A "android;15;default" -d "detail=aaaaa" "http://test.com/"
    posted @ 2013-12-18 11:07 一凡 閱讀(278) | 評論 (0)編輯 收藏
    update test set create_time=concat('2013-10-01 ', floor(10+rand()*10),':',floor(10+rand()*49),':',floor(10+rand()*49))  where create_time='0000-00-00 00:00:00'
    posted @ 2013-12-05 16:51 一凡 閱讀(747) | 評論 (1)編輯 收藏
    load data infile '/tmp/test.txt' into table test character set utf8 (col1,col2,col3);
    綠色部分在mysql參考手冊中都沒有描述,坑爹啊!!!!!!!!
    posted @ 2013-12-02 14:52 一凡 閱讀(607) | 評論 (0)編輯 收藏
    #17點至23點
    ls -l xxxx.log.20131117{1[7-8],2[0-3]}
    posted @ 2013-11-20 18:26 一凡 閱讀(198) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 久久久国产精品亚洲一区| 西西人体免费视频| 亚洲精品国产免费| 亚洲日韩涩涩成人午夜私人影院| 免费人成视频在线| 99久久免费精品高清特色大片| 免费人成又黄又爽的视频在线电影| 亚洲乱码无限2021芒果| 亚洲AV电影院在线观看| 自拍偷自拍亚洲精品第1页 | 一本色道久久综合亚洲精品高清| 大学生一级特黄的免费大片视频| 在线看片免费人成视久网| 国产免费无码一区二区| 最新亚洲成av人免费看| EEUSS影院WWW在线观看免费 | 亚洲一区精品伊人久久伊人| 日韩一级在线播放免费观看| 成全影视免费观看大全二| 日本三级2019在线观看免费| 亚洲啪啪免费视频| 亚洲综合免费视频| 亚洲精品视频在线免费| h视频在线观看免费完整版| 最刺激黄a大片免费网站| 久久国产色AV免费观看| 91久久青青草原线免费| 亚洲成人在线免费观看| 真人做A免费观看| 男女免费观看在线爽爽爽视频| 国内精品免费麻豆网站91麻豆| 波多野结衣免费在线| 国产精品入口麻豆免费观看| 91精品免费在线观看| 日本三级2019在线观看免费| 最近中文字幕mv免费高清电影| 四虎影院在线免费播放| 国产小视频免费观看| 亚洲一区二区三区在线播放| 亚洲人成影院在线无码按摩店| 久久综合九九亚洲一区|