一點(diǎn)一滴,編程人生

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            69 隨筆 :: 0 文章 :: 25 評(píng)論 :: 0 Trackbacks

          2015年1月3日 #

          今天為了這個(gè)問題了忙乎了一整天,特此記錄下,希望對(duì)有遇到同樣問題的同學(xué)有幫助。事情的經(jīng)過是這樣的,原先使用atomikos一直把數(shù)據(jù)源用jndi配置到tomcat的context.xml下,一直這么用沒有出現(xiàn)問題,配置如下
              <Resource name="jdbc/cms" auth="Container"
                  type
          ="com.atomikos.jdbc.AtomikosDataSourceBean" factory="com.atomikos.tomcat.EnhancedTomcatAtomikosBeanFactory"
                  uniqueResourceName
          ="jdbc/cms" xaDataSourceClassName="com.mysql.jdbc.jdbc2.optional.MysqlXADataSource"
                  xaProperties.URL
          ="xxxx"
                  xaProperties.user
          ="xxxx" xaProperties.password="xxxx"
                  xaProperties.pinGlobalTxToPhysicalConnection
          ="true" maxLifetime="60" poolSize="4" />

          最近項(xiàng)目要遷移到maven下,所以把context.xml的數(shù)據(jù)源配置挪到了spring.xml下,配置如下
              <bean id="myDataSource" class="com.atomikos.jdbc.AtomikosDataSourceBean" init-method="init" destroy-method="close">
                 
          <property name="uniqueResourceName" value="masterDB" />
                 
          <property name="xaDataSourceClassName" value="com.mysql.jdbc.jdbc2.optional.MysqlXADataSource"/>  <!-- SQLErrorCodes loaded: [DB2, Derby, H2, HSQL, Informix, MS-SQL, MySQL, Oracle, PostgreSQL, Sybase, Hana]  -->  
                 
          <property name="poolSize" value="0" /> 
                 
          <property name="minPoolSize" value="0"/>    
                 
          <property name="maxPoolSize" value="9"/>    
                 
          <property name="borrowConnectionTimeout" value="60"/>    
                 
          <property name="reapTimeout" value="20"/>    
                 
          <property name="maxIdleTime" value="60"/>    
                 
          <property name="maintenanceInterval" value="60"/>    
                 
          <property name="loginTimeout" value="60"/>
                 
          <property name="xaProperties">  
                      
          <props>
                          
          <prop key="url">xxxx</prop>  
                          
          <prop key="user">xxxx</prop>
                          
          <prop key="password">xxxx</prop>
                      
          </props>
                  
          </property>  
              
          </bean>
          因?yàn)樯厦孢@個(gè)配置我是照搬網(wǎng)上的,所以覺得沒有問題,可是項(xiàng)目啟動(dòng)后,用此數(shù)據(jù)源提交事務(wù)時(shí)確報(bào)以下錯(cuò)誤:

          Raised -5: invalid arguments were given for the XA operation 或 XAER_INVAL: Invalid arguments (or unsupported command)

          一開始我以為maven配置的mysql-connector-java驅(qū)動(dòng)版本不對(duì),或是atomikos版本不對(duì),可是不管如何換版本都不行,就快要瘋了的時(shí)候,我看到了原先jndi方式中有這么一行代碼
          xaProperties.pinGlobalTxToPhysicalConnection="true"
          就因?yàn)槿鄙偕厦孢@句話導(dǎo)致了問題,上網(wǎng)查資料,據(jù)說是mysql xa bug,有興趣的可以看如下連接,最后配置如下:
                 <property name="xaProperties">  
                      
          <props>
                          
          <prop key="pinGlobalTxToPhysicalConnection">true</prop>  <!-- mysql必須配置此參數(shù),要不然無法提交事務(wù) -->
                          
          <prop key="url">xxxx</prop>  
                          
          <prop key="user">xxx</prop>
                          
          <prop key="password">xxxx</prop>
                      
          </props>
                  
          </property> 



          posted @ 2017-06-28 19:32 writegull 閱讀(2506) | 評(píng)論 (0)編輯 收藏

          事情描述:
          本人在阿里云上創(chuàng)建了一個(gè)linux服務(wù)器,跑了一個(gè)自己的測(cè)試web項(xiàng)目。搭建了redis。想方便測(cè)試用,就沒有對(duì)redis進(jìn)行任何安全防護(hù)并暴露在了公網(wǎng)上。期間阿里云發(fā)現(xiàn)了此問題,還發(fā)短信提醒我,由于最近在公司一直加班也沒有時(shí)間理會(huì),沒想到就在今天真的被黑了,事后心想多虧是個(gè)測(cè)試服務(wù)器,如果是正式環(huán)境,也真危險(xiǎn),這個(gè)黑客也沒有停下腳步,通過redis強(qiáng)大的能力在/root/.ssh目錄下面上傳了公鑰,徹底攻破了服務(wù)器,免密碼登錄服務(wù)器,一般黑客到這步也就看看有沒有興趣的數(shù)據(jù),這個(gè)黑客一看這就是個(gè)沒有價(jià)值的測(cè)試服務(wù)器,所以心一橫,在我這上面裝了個(gè)DDOS攻擊軟件,把我的機(jī)器當(dāng)起肉雞。

          1.這就是黑完后留下的公鑰/私鑰,刪除authorized_keys,id_rsa, id_rsa.pub這三個(gè)文件吧,除非還想讓他繼續(xù)黑下去。。。。


          2.通過redis的key *命令可以看到有個(gè)叫crackit的key。這就是黑客在入侵后留下來的,原先set的值是公鑰,入侵成功之后就改成這個(gè)了,把這個(gè)key也刪除掉吧。


          3.修改redis默認(rèn)端口吧,不讓黑客利用6379端口。在redis安裝目錄中,修改redis.config文件。修改完了別忘了重啟redis服務(wù),

          # redis-server /etc/redis/redis.conf 開啟

          # redis-cli shutdown 關(guān)閉



          4.重啟后查看redis是否運(yùn)行
          ps -x | grep redis
          5.通過指定端口訪問redis。
          redis-cli -p 6666

          6.給redis設(shè)置密碼或者干脆設(shè)置成只能內(nèi)網(wǎng)訪問

          7.通過top命令發(fā)現(xiàn)了幾個(gè)可疑的程序



          8.minerd這個(gè)程序是個(gè)用來挖掘萊特幣的,這個(gè)黑客看來干了不少壞事啊。。我們用命令 ps -ef|grep minerd 查找一下這個(gè)進(jìn)程,殺掉這個(gè)進(jìn)程kill -9 18267,并且去/tmp目錄刪除minerd目錄


          9.黑客在tmp目錄留下了一個(gè)叫1.sh的腳本,是用來下載挖掘萊特幣程序的。也把它kill掉吧。以下是腳本內(nèi)容。


          10.通過cat /etc/passwd命令可以看到有一個(gè)叫作syss的非法用戶,權(quán)限還很高,跟root一樣,刪掉他吧,這是黑客入侵后方便進(jìn)入的。使用命令userdel -f syss 強(qiáng)制刪除一個(gè)用戶,哪怕他正在登錄。


          11.去/mnt目錄上,可以看到黑客掛載了很多程序,刪除他們吧。


          12.通過nethogs軟件可以按進(jìn)程實(shí)時(shí)統(tǒng)計(jì)網(wǎng)絡(luò)帶寬利用率,這個(gè)用來看是否存在DDOS攻擊最好不過了。

          13.暫時(shí)解決對(duì)外DDOS攻擊,最快的辦法就是用防火墻,這個(gè)阿里云提供的腳本幫了大忙。直接上傳到服務(wù)器上,運(yùn)行一下世界就清靜了。下載地址:
          https://help.aliyun.com/knowledge_detail/5973920.html?spm=5176.7618386.5.1.H8H33f

           
          posted @ 2015-12-15 01:13 writegull 閱讀(4134) | 評(píng)論 (4)編輯 收藏

          今天在修改server.xml調(diào)試程序時(shí),遇到下面這個(gè)問題,clean,重啟都不好使。

                          Removing obsolete files from server..
                         Could not clean server of obsolete files: null
                          java.lang.NullPointerException
          解決方法是把.metadata\.plugins\org.eclipse.wst.server.core這個(gè)目錄下面的tmp0刪除掉,再clean下就可以了。可能是緩存問題。
          posted @ 2015-01-03 16:58 writegull 閱讀(7292) | 評(píng)論 (0)編輯 收藏

          主站蜘蛛池模板: 双城市| 天长市| 阜康市| 阿鲁科尔沁旗| 海原县| 厦门市| 镇赉县| 云和县| 普格县| 嘉善县| 运城市| 汉川市| 阿坝| 柘荣县| 安康市| 苗栗县| 敦化市| 淮阳县| 镇坪县| 都江堰市| 丰台区| 合水县| 米脂县| 石泉县| 台江县| 惠州市| 东阿县| 额尔古纳市| 昌宁县| 老河口市| 漯河市| 宁波市| 辉南县| 吴忠市| 汝阳县| 时尚| 南澳县| 西乌| 嫩江县| 永仁县| 门头沟区|