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

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

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

    posts - 27,comments - 2,trackbacks - 0
    做個總結
    linux服務器上做負載均衡
    自己準備的:linux服務器(45.78.20.168),jdk1.7,nginx,redis,tomcat7兩個,部署的項目;

    1:jdk1.7安裝,兩個tomcat分別端口8080,8081;部署相同的項目;啟動;
        http://45.78.20.168:8080/redis3.2/getRedis.action
        http://45.78.20.168:8081/redis3.2/getRedis.action
    2:安裝nginx,添加負載的配置,安裝目錄下找 /etc/nginx/conf.d/default.conf文件(或/etc/nginx/nginx.conf);策略設置為默認輪詢;
        upstream www.nimenhaihaoma.com {
            server 45.78.20.168:8080;
            server 45.78.20.168:8081;
        }
        server{
            listen 80;
            server_name www.nimenhaihaoma.com;
            location / {
                proxy_pass http://www.nimenhaihaoma.com;
                proxy_set_header Host $host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            }
    3:配置session共享,方式很多,這里用的redis的session共享(兼容jdk版本至少1.7):
        tomcat的lib包加commons-pool2-2.0.jar,jedis-2.5.2.jar,tomcat-redis-session-manager1.2.jar;
        tomcat配置文件context.xml,在標簽<Context>內添加配置:
            <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
            <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager" host="localhost" port="6379" database="0" maxInactiveInterval="60" />

    4:項目里面區分session的代碼:
        (1):放session的接口(執行一次);
        (2):取session數據(不斷刷新),看tomcat打印信息;
    5:效果,http://www.nimenhaihaoma.com/redis3.2/getRedis.action (狂刷session值相同)



    posted @ 2016-08-17 17:03 魏文甫 閱讀(122) | 評論 (0)編輯 收藏
    項目只是加載spring的幾個定時任務,啟動服務一直循環加載spring文件,問題的根節點:定時器類里面的service對象采取配置的方式注入,而這個定時器類的構造讓我給加上了:
    ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext*.xml");
    myServiceImpl = context.getBean("XXXService");

    加上這段為了方便測試,在該類里寫main方法測試執行,把調用寫到構造里;,spring定時器配置好時間后,此處構造忘了去掉;導致啟動tomcat服務一直在加載spring注入文件;
    同理,spring注入的方式,在action里同樣有這樣的效果,構造方法一定注意;
    posted @ 2015-04-25 11:09 魏文甫 閱讀(178) | 評論 (0)編輯 收藏
    是在build.xml編譯的時候,包里有兩個類名一樣的java文件,我只是做了個備份,忘了改文件后綴,備份的文件也編譯了,所以報的這個錯
    posted @ 2014-08-28 20:18 魏文甫 閱讀(840) | 評論 (0)編輯 收藏
    1,添加索引文件中的一條新的索引     
                    Question addQ = new Question();//新添加的一條數據,對象id在索引文件中沒有
                    addQ.setId("999999999");
                    addQ.setQuestionname("新添加的一條數據名稱");
                    Analyzer sa = new SmartChineseAnalyzer(Version.LUCENE_40);
    IndexWriterConfig iwc = new IndexWriterConfig(Version.LUCENE_40, sa);
    iwc.setOpenMode(OpenMode.APPEND);
    IndexWriter writer = null;
    try {
    Directory dir1 = FSDirectory.open(new File("F:\\temp"));
    writer = new IndexWriter(dir1, iwc);
    FieldType ft = new FieldType();
    ft.setIndexed(true);
    ft.setStored(true);
    ft.setTokenized(true);
    FieldType ft2 = new FieldType();
    ft2.setIndexed(true);
    ft2.setStored(true);
    ft2.setTokenized(false);
    Document doc = new Document();
    doc.add(new Field("id", addQ.getId(), ft2));
    doc.add(new Field("questionname", addQ.getQuestionname(), ft));
    writer.addDocument(doc);
    writer.close();
    } catch (CorruptIndexException e) {
    e.printStackTrace();
    } catch (LockObtainFailedException e) {
    e.printStackTrace();
    } catch (IOException e) {
    e.printStackTrace();
    } finally{
    try {
    if(writer!=null){
    writer.close();
    }
    if(sa!=null){
    sa.close();
    }
    } catch (CorruptIndexException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    }
    執行完程序后,索引文件中已經添加新的索引數據。
    2,刪除索引文件中的一條新的索引
                    Question delQ = new Question();//索引文件中有的一條數據,根據對象id刪
                    delQ.setId("1111111");
                    delQ.setQuestionname("要刪除的一條數據");
                    IndexWriter writer = null;
    Analyzer sa = new SmartChineseAnalyzer(Version.LUCENE_40);
    IndexWriterConfig iwc = new IndexWriterConfig(Version.LUCENE_40, sa);
    Directory dir1 = null;
    try {
    dir1 = FSDirectory.open(new File("F:\\temp"));
    writer = new IndexWriter(dir1, iwc);
    Term term = new Term("id", delQ.getId());
    writer.deleteDocuments(term);
    writer.commit();
    writer.close();
    } catch (CorruptIndexException e) {
    e.printStackTrace();
    } catch (LockObtainFailedException e) {
    e.printStackTrace();
    } catch (IOException e) {
    e.printStackTrace();
    } finally {
    try {
    if (writer != null) {
    writer.close();
    sa.close();
    }
    } catch (CorruptIndexException e) {
    e.printStackTrace();
    } catch (IOException e) {
    e.printStackTrace();
    }
    }
    System.out.println("索引刪除完成");
    3,更新索引文件中的一條索引
    更新索引文件中的一條索引的理念是:先找到這條索引刪除,然后再添加這條更新后的索引


    posted @ 2013-08-16 12:08 魏文甫 閱讀(341) | 評論 (0)編輯 收藏
                    IndexReader reader = DirectoryReader.open(FSDirectory.open(new File("F:\\temp")));// 打開索引
    IndexSearcher searcher = new IndexSearcher(reader);
    Analyzer analyzer = new SmartChineseAnalyzer(Version.LUCENE_40);
    String[] fields = { "questionname","id" };
    Occur[] occurs = new Occur[] { Occur.SHOULD,Occur.SHOULD };
    Query query =  MultiFieldQueryParser.parse(Version.LUCENE_40, "測試 的", fields,
    occurs, analyzer);
    TopDocs result = searcher.search(query, searcher.getIndexReader()
    .maxDoc());
    ScoreDoc[] hits = result.scoreDocs;
    List<Document> list = new ArrayList<Document>();
    for (int i = 0; i <hits.length; i++) {
    Document doc = searcher.doc(hits[i].doc);
    list.add(doc);
    }
    System.out.println("搜索list的長度\t→→→→\t"+list.size());
    for (Document document : list) {
    System.out.println(document.getField("questionname"));
    }
    analyzer.close();

    注:紅色字體是輸入的檢索條件,多個用空格隔開,找到的結果先匹配同時符合多個的結果,結果只是拿過來的document一個list集合,具體結果再解析就行了。

    結果如圖:
    posted @ 2013-08-12 17:26 魏文甫 閱讀(1174) | 評論 (1)編輯 收藏
                    Connection conn = null;
    Statement stat = null;
    ResultSet rs = null;
    Analyzer sa = new SmartChineseAnalyzer(Version.LUCENE_40);
    IndexWriterConfig iwc = new IndexWriterConfig(Version.LUCENE_40, sa);
    iwc.setOpenMode(OpenMode.CREATE);
    Directory dir1 = FSDirectory.open(new File("F:\\temp"));
    IndexWriter writer = new IndexWriter(dir1, iwc);
    int numIndexed = -1;
    FieldType ft = new FieldType();
    ft.setIndexed(true);
    ft.setStored(true);
    ft.setTokenized(true);
    FieldType ft2 = new FieldType();
    ft2.setIndexed(true);
    ft2.setStored(true);
    ft2.setTokenized(false);
    Class.forName("com.mysql.jdbc.Driver");
    conn = (Connection) DriverManager.getConnection(
    "jdbc:mysql:///question", "root", "root");
    stat = (Statement) conn.createStatement();
    rs = stat.executeQuery("select id,questionname from question");
    List<String> list = new ArrayList<String>();
    while (rs.next()) {
    String id = rs.getString("questionname");
    String questionname = rs.getString("questionname");
    list.add(id);
    list.add(questionname);
    }
    rs.close();
    stat.close();
    conn.close();
    for (String string : list) {
    Document doc = new Document();
    doc.add(new Field("questionname", string, ft2));
    writer.addDocument(doc);
    }
    numIndexed = writer.maxDoc();
    writer.close();
    執行完這段程序f盤多一個文件夾temp,里面就是創建好的索引文件了,然后進行根據索引文件查詢
    posted @ 2013-08-12 16:50 魏文甫 閱讀(1416) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 一级一级一片免费高清| 久久免费视频精品| 免费观看黄网站在线播放| 久久精品亚洲一区二区三区浴池| 久久免费美女视频| 久久亚洲高清观看| 久久国产精品成人片免费| 精品日韩亚洲AV无码| 57pao国产成永久免费视频| 亚洲男女性高爱潮网站| 免费无码VA一区二区三区| 亚洲黄色在线视频| 国产成在线观看免费视频| 中中文字幕亚洲无线码| 国产麻豆免费观看91| 曰韩无码AV片免费播放不卡| 久久精品国产精品亚洲人人| 最好免费观看高清在线| 2022年亚洲午夜一区二区福利| 在线观看成人免费视频不卡| 香蕉大伊亚洲人在线观看| 国产免费变态视频网址网站 | 亚洲精品色婷婷在线影院| 一本久久A久久免费精品不卡| 国产AⅤ无码专区亚洲AV| 99热在线精品免费播放6| 2020久久精品亚洲热综合一本| 波多野结衣久久高清免费| 人妻仑乱A级毛片免费看| 亚洲国产国产综合一区首页| 999国内精品永久免费观看| 色偷偷亚洲第一综合| 国产亚洲人成网站在线观看不卡 | 成年18网站免费视频网站 | 久操视频免费观看| 亚洲乱码在线观看| 亚洲色偷拍区另类无码专区| 日韩精品无码免费一区二区三区 | 久久九九全国免费| 亚洲暴爽av人人爽日日碰| 亚洲精品国产精品乱码在线观看 |