成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

分布式軟件架構(gòu)整合(二)

you_De / 1544人閱讀

摘要:續(xù)上篇所需技術(shù)等說明本編講解一個分布式架構(gòu)的整個流程,首先對上編中的工程作一些小小的改動,以支持接下來的實驗。本篇中,定義了服務(wù)提供者,注冊中心及客戶端消費者三者關(guān)系。一服務(wù)提供者這里首先對服務(wù)端進行改造。

(續(xù)上篇)

所需技術(shù):spring、mybatis、druid、flyway、logback、nodejs,zookeeper,dubbo,dubbo-admin等;
說明:本編講解一個分布式架構(gòu)的整個流程,首先對上編中的demo工程作一些小小的改動,以支持接下來的實驗。特別說明,zookeeper作為服務(wù)注冊中心,dubbo-admin作為注冊中心管理客戶端,雖然都是開源軟件,但本章不作安裝部署講解。

目錄結(jié)構(gòu)調(diào)整上圖所示,紅框中,作為調(diào)整內(nèi)容,其它內(nèi)容不變。

簡要
本篇引入了阿里公司開源的分布式服務(wù)框架[dubbo][1]。本篇中,定義了provider服務(wù)提供者,zookeeper注冊中心及客戶端消費者三者關(guān)系。provider是數(shù)據(jù)源,基于底層的數(shù)據(jù)交互都在這里完成。provider將服務(wù)暴露給zookeeper注冊中心,provider的所有服務(wù)都由zookeeper進行統(tǒng)一管理。client作為消費者,連接到注冊中心獲取相應(yīng)的服務(wù)。
本文中消費者部分由nodejs編寫。


一、Provider服務(wù)提供者
這里首先對服務(wù)端進行改造。提供兩個接口,各一個方法。DemoService接口中提供一個方法,客戶端傳入String型參數(shù),處理此參數(shù)后返回客戶端。IUserService接口中提供一個根據(jù)id查詢用戶信息的方法。方法實現(xiàn)同上篇文中介紹一樣不變。部分代碼如下:

DemoServiceImpl.java

package com.soyann.provider.demo.impl;

import com.soyann.provider.demo.DemoService;

/**
 * @ProjectName: soyann
 * @FileName: com.soyann.provider.demo.impl
 * @Description: (do what)
 * @Copyright: Copyright(C) 2016-2017 All rights Reserved
 * @Company: ShenZhen Information Technology Co.,LTD.
 * @Author: neil
 * @Version V1.0
 * @Date: 2017/11/17
 * 

* Modification History: * Date Author Version Discription * ----------------------------------------------------------------------------------- * 2017/11/17 neil 1.0 1.0 * Why & What is modified: <修改原因描述> */ public class DemoServiceImpl implements DemoService { @Override public String sayHello(String name) { return "Hello Dubbo,Hello " + name; } }

UserServiceImpl.java

package com.soyann.provider.user.service.impl;

import com.soyann.provider.user.mapper.UserMapper;
import com.soyann.provider.user.model.UserEntity;
import com.soyann.provider.user.service.IUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * @ProjectName: soyann
 * @FileName: com.soyann.business.user.service.impl
 * @Description: (do what)
 * @Copyright: Copyright(C) 2016-2017 All rights Reserved
 * @Company: ShenZhen Information Technology Co.,LTD.
 * @Author: dell657 neil
 * @Version V1.0
 * @Date: 2017/10/28
 * 

* Modification History: * Date Author Version Discription * ----------------------------------------------------------------------------------- * 2017/10/28 neil 1.0 1.0 * Why & What is modified: <修改原因描述> */ @Service("userService") public class UserServiceImpl implements IUserService { @Autowired(required=false) private UserMapper userMapper; @Override public UserEntity getUserById(int userId) { return userMapper.selectByPrimaryKey(userId); } @Override public List getAllUser() { return userMapper.getAllUser(); } }

spring-provider.xml



    
    
    
    
    
    


    
    
    
    


    
    
    
    


在spring-applicationContext.xml中,引入spring-provider.xml

添加服務(wù)啟動測試類TestProvider.java

package com.soyann.demo;

import org.springframework.context.support.ClassPathXmlApplicationContext;

import java.io.IOException;

/**
 * @ProjectName: soyann
 * @FileName: com.soyann.demo
 * @Description: (do what)
 * @Copyright: Copyright(C) 2016-2017 All rights Reserved
 * @Company: ShenZhen Information Technology Co.,LTD.
 * @Author: neil
 * @Version V1.0
 * @Date: 2017/11/17
 * 

* Modification History: * Date Author Version Discription * ----------------------------------------------------------------------------------- * 2017/11/17 neil 1.0 1.0 * Why & What is modified: <修改原因描述> */ public class TestProvider { public static void main(String[] args) throws IOException { ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring/spring-applicationContext.xml", "spring/spring-mybatis.xml"); System.out.println(context.getDisplayName() + ": here"); context.start(); System.out.println("服務(wù)已經(jīng)啟動..."); System.in.read(); } }

運行測試類,輸出以下信息:

……
18:45:48.299 [main] DEBUG ResultSet - {conn-10010, stmt-20003, rs-50003} Header: [installed_rank, version, description, type, script, checksum, installed_on, installed_by, execution_time, success]
18:45:48.299 [main] DEBUG ResultSet - {conn-10010, stmt-20003, rs-50003} closed
18:45:48.299 [main] DEBUG Statement - {conn-10010, stmt-20003} closed
18:45:48.299 [main] INFO  DbMigrate - Current version of schema `soyann`: 1.0.1
18:45:48.299 [main] WARN  DbMigrate - Schema `soyann` has version 1.0.1, but no migration could be resolved in the configured locations !
18:45:48.300 [main] DEBUG Statement - {conn-10010, pstmt-20004} created. SELECT RELEASE_LOCK("Flyway--294804349")
18:45:48.300 [main] DEBUG Statement - {conn-10010, pstmt-20004} Parameters : []
18:45:48.300 [main] DEBUG Statement - {conn-10010, pstmt-20004} Types : []
18:45:48.300 [main] DEBUG Statement - {conn-10010, pstmt-20004} executed. 0.414796 millis. SELECT RELEASE_LOCK("Flyway--294804349")
18:45:48.300 [main] DEBUG Statement - {conn-10010, pstmt-20004} clearParameters. 
18:45:48.300 [main] INFO  DbMigrate - Schema `soyann` is up to date. No migration necessary.
18:45:48.301 [main] DEBUG Connection - {conn-10010} setAutoCommit false
18:45:48.301 [main] DEBUG Connection - {conn-10010} commited
18:45:48.301 [main] DEBUG Connection - {conn-10010} setAutoCommit true
18:45:48.302 [main] DEBUG Connection - {conn-10010} pool-recycle
18:45:48.527 [main] DEBUG SqlSessionFactoryBean - Parsed configuration file: "class path resource [mybatis/mybatis-config.xml]"
18:45:48.674 [main] DEBUG SqlSessionFactoryBean - Parsed mapper file: "file [D:workspaceJAVAsoyannprovider	argetclassesmybatismappersqlmap-mapping-user.xml]"
org.springframework.context.support.ClassPathXmlApplicationContext@f2a0b8e: here
服務(wù)已經(jīng)啟動...

這樣表示服務(wù)已經(jīng)發(fā)布成功?。▃ookeeper注冊中心要先啟動,啟動方法略)

二、服務(wù)消費者部分
消費者部分采用node工程,這里也簡單創(chuàng)建了一個node工程進行連接實驗。目錄結(jié)構(gòu)如下:

這里,必須的文件有三個文件,package.json,server.js,soyannClient-route.js

package.json

{
  "name": "nodeClient",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo "Error: no test specified" && exit 1",
    "build": "babel src -d lib"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "dependencies": {
    "cookie-parser": "^1.4.3",
    "express": "^4.16.2",
    "http": "^0.0.0",
    "js-to-java": "^2.4.0",
    "morgan": "^1.9.0",
    "node-zookeeper-dubbo": "^2.2.1"
  },
  "devDependencies": {
    "babel-cli": "^6.26.0",
    "babel-preset-env": "^1.6.1"
  }
}

server.js

/**
 * @ProjectName: nodeClient
 * @FileName:
 * @Description: (服務(wù)主入口)
 * @Copyright: Copyright(C) 2016-2017 All rights Reserved
 * @Company: ShenZhen Information Technology Co.,LTD.
 * @Author: dell657 neil
 * @Version V1.0
 * @Date:  2017/11/17
 *
 * Modification  History:
 * Date         Author        Version        Discription
 * -----------------------------------------------------------------------------------
 * 2017/11/17     neil          1.0             1.0
 * Why & What is modified: <修改原因描述>
 */

const logger = require("morgan"),
    http = require("http"),
    express = require("express"),
    bodyParser = require("body-parser"),
    debug = require("debug")("mydebug:http"),
    cookieParser = require("cookie-parser");


const app = express();
//設(shè)置跨域訪問
app.all("*", function (req, res, next) {
    if(req.headers.origin == "http://localhost:4200" || req.headers.origin == "http://ng2.com"){
        res.header("Access-Control-Allow-Origin",req.headers.origin);   //設(shè)置跨域訪問
        res.header("Access-Control-Allow-Credentials", "true");
        res.header("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS");
        res.header("Access-Control-Allow-Headers", "Origin, No-Cache, X-Requested-With, If-Modified-Since, Pragma, Last-Modified, Cache-Control, Expires, Content-Type, X-E4M-With, Authorization");
        res.header("Content-Type", "application/json");
    }
    next();
});


app.use(bodyParser.urlencoded({extended: true}));
app.use(bodyParser.json());

app.use(function (err, req, res, next) {
    if (err.name === "StatusError") {
        res.send(err.status, err.message);
    } else {
        next(err);
    }
});

/*引用模塊*/
app.use(require("./modules/soyannClient-route"));
//app.use(require("./modules/zkclient-route"));

/*監(jiān)聽端口*/
const port = process.env.PORT || 8090;
http.createServer(app).listen(port, function (err) {
    console.log("Node服務(wù)已啟動,請訪問:http://localhost:" + port);
});

soyannClient-route.js

/**
 * @ProjectName: nodeClient
 * @FileName:
 * @Description: (do what)
 * @Copyright: Copyright(C) 2016-2017 All rights Reserved
 * @Company: ShenZhen Information Technology Co.,LTD.
 * @Author: dell657 neil
 * @Version V1.0
 * @Date:  2017/11/17
 *
 * Modification  History:
 * Date         Author        Version        Discription
 * -----------------------------------------------------------------------------------
 * 2017/11/17     neil          1.0             1.0
 * Why & What is modified: <修改原因描述>
 */
const express = require("express"),
    debug = require("debug")("mydebug:http"),
    zookeeperClient = require("node-zookeeper-dubbo");

const app = module.exports = express.Router();

const opt = {
    application: {name: "soyann-provider"},
    register: "localhost:2181",
    dubboVer: "2.5.7",
    root: "dubbo",
    dependencies: {
        Demo: {
            interface: "com.soyann.provider.demo.DemoService",
            version: "1.0.0",
            timeout: 6000,
            group: "g-demo",
            methodSignature: {
                sayHello: sayHello = (name) => (java) => [ java.String(name) ]
            }
        },
        Soyann: {
            interface: "com.soyann.provider.user.service.IUserService",
            version: "2.0.0",
            timeout: 6000,
            group: "g-soyann",
            methodSignature: {
                getUserById: getUserById = (id) => [ {"$class": "int", "$": id} ]
            }
        }
    }
};

opt.java = require("js-to-java");

const Dubbo = new zookeeperClient(opt);



/*傳參數(shù)實例*/
app.post("/api/sayHello",(req,res)=>{
    debug(req);
    Dubbo.Demo
        .sayHello(req.body.name)
        .then(data=>res.send(data))
        .catch(err=>res.send(err))
});

/*傳遞整形參數(shù)*/
app.post("/api/getUserById",(req,res)=>{
    Dubbo.Soyann
        .getUserById(Number(req.body.id))
        .then(data=>res.send(data))
        .catch(err=>res.send(err))
});


/*訪問實例*/
app.get("/api/demo",(req,res)=>{
    const result={"result":"Hello world Neil!"};
    debug(result);
    res.status(200).send(result);
});

這個工程中,使用了node-zookeeper-dubbo這個開源模塊,使得node與java通信成為現(xiàn)實。

啟動工程,后面不用再說了吧,本篇完結(jié)。

http://dubbo.io/

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/68047.html

相關(guān)文章

  • 哪種Scale out架構(gòu)能更有效滿足布式計算?

    摘要:那么,的架構(gòu)是否真的需要多臺小計算量的節(jié)點來實現(xiàn)才是最完美的架構(gòu)呢,讓我們來細細剖析什么樣的架構(gòu)才能最有效的滿足分布式計算的特點。近些年,隨著分布式計算的越來越火熱,Scale out分布式應(yīng)用架構(gòu)也如雨后春筍般不斷涌現(xiàn),大到Big Data平臺架構(gòu),小到前端應(yīng)用App的架構(gòu),似乎都要基于Scale out 的架構(gòu)才算是與時俱進的先進架構(gòu)。分布式架構(gòu)的優(yōu)勢顯而易見,一方面,Scale out...

    idisfkj 評論0 收藏0
  • 布式軟件架構(gòu)整合(一)

    摘要:通過整合及可以實現(xiàn)數(shù)據(jù)庫查詢后將數(shù)據(jù)持久化。但是可能出現(xiàn)幻像讀這是花費最高代價但是最可靠的事務(wù)隔離級別。事務(wù)被處理為順序執(zhí)行。 所需技術(shù):spring、mybatis、druid、flyway、logback、nodejs、html、css3 ;目標:創(chuàng)建一個業(yè)務(wù)框架,后端采用spring+mybatis,中間層采用node,前端html5,css3等; showImg(https:/...

    mochixuan 評論0 收藏0
  • 云存儲主要技術(shù)路線選型比較

    摘要:云存儲主要技術(shù)路線有哪些各有哪些優(yōu)缺點分享一存儲虛擬化存儲虛擬化更多是對傳統(tǒng)塊的虛擬化。也是云存儲的主流當家花旦。哪些應(yīng)用場景適合云存儲?存儲虛擬化、分布式存儲、對象存儲這幾種技術(shù)主要解決什么問題?技術(shù)產(chǎn)品選型如何考慮? 企業(yè)哪些應(yīng)用場景適合借助云存儲來實現(xiàn)? 傳統(tǒng) IT 環(huán)境中使用傳統(tǒng)存儲的困境有那些?那些應(yīng)用場景是傳統(tǒng)存儲不能滿足而必須借助云存儲來實現(xiàn)的? 分享一: ...

    zlyBear 評論0 收藏0
  • 墻裂推薦:搜云庫技術(shù)團隊,面試必備的技術(shù)干貨

    摘要:今天整理了一下近大半年以來的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉(zhuǎn)發(fā)。 今天整理了一下近大半年以來的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉(zhuǎn)發(fā)。 面試必備 面試必備:深入Spring MVC DispatchServlet 源碼...

    SegmentFault 評論0 收藏0
  • 墻裂推薦:搜云庫技術(shù)團隊,面試必備的技術(shù)干貨

    摘要:今天整理了一下近大半年以來的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉(zhuǎn)發(fā)。 今天整理了一下近大半年以來的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉(zhuǎn)發(fā)。 面試必備 面試必備:深入Spring MVC DispatchServlet 源碼...

    Neilyo 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<