通過java的jsch連接遠程數(shù)據(jù)庫
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供潮州網(wǎng)站建設(shè)、潮州做網(wǎng)站、潮州網(wǎng)站設(shè)計、潮州網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、潮州企業(yè)網(wǎng)站模板建站服務(wù),10余年潮州做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。有時候我們本地代碼可能無法連接數(shù)據(jù)庫,因為數(shù)據(jù)庫增加了白名單,指定ip的服務(wù)器才可以連接到數(shù)據(jù)庫,不過我們可以通過連接該指定ip的服務(wù)器,然后通過該服務(wù)器連接數(shù)據(jù)庫,就像很多數(shù)據(jù)庫可視化軟件一樣。通過使用jsch,我們也可以在代碼層面實現(xiàn)這個功能。話不多說,直接開碼:
JSch jsch = new JSch(); Session sess; //這里xxx.xxx.xxx.xxx為已加白名單的遠程服務(wù)器 sess = jsch.getSession("ubuntu", "xxx.xxx.xxx.xxx", 22); sess.setPassword("*******"); sess.setConfig("StrictHostKeyChecking", "no"); sess.connect(); //這里xxx.xxx.xxx.xxx為數(shù)據(jù)庫連接地址 //通過這個set方法可以將遠程的3306端口指定為本地的3308端口,因為筆者本地3306已使用,故指定為3308端口 sess.setPortForwardingL(3308,"xxx.xxx.xxx.xxx",3306); try { //讀取配置文件,需要注意的是,這里的配置文件中數(shù)據(jù)庫地址為localhost,端口為剛剛指定的3308 reader = Resources.getResourceAsReader("conf.xml"); } catch (IOException e) { e.printStackTrace(); } sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); SqlSession session = sqlSessionFactory.openSession(); String statement = "com.saishangmingzhu.getData";//映射sql的標識字符串 List ll=session.selectList(statement); System.out.println(ll); session.commit(); session.close(); sess.disconnect();當然,使用jsch實現(xiàn)ssh連接不僅僅限于實現(xiàn)數(shù)據(jù)庫的連接,還可以對ssh連接上的服務(wù)器進行操作,比如執(zhí)行shell等相關(guān)命令,后續(xù)再做記錄吧
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。