code-desc

1煌集、SpringCloud-feign

@FeignClient(value = "book-auth-service", fallback = AuthFallBackService.class)
public interface AuthService {
    @GetMapping("/auth/authorities")
    ResJson<Set<String>> getAuthorities(@RequestParam("loginName") String loginName);

    @GetMapping("/auth/validateJwtToken")
    ResJson<Boolean> validateJwtToken(@RequestParam("token") String token);

    @GetMapping("/auth/getLoginName")
    ResJson<String> getUserLoginNameByToken(@RequestParam("token") String token);

    @GetMapping("/auth/authuser")
    ResJson<String> authUser(@RequestParam("token") String token);
}

@FeignClient(value = "book-auth-service", fallback = AuthFallBackService.class)
調(diào)用遠程服務(wù)
value:為注冊到Eureka中的服務(wù)名稱
fallback:解決調(diào)用的服務(wù)不可用時(使用hytrix)苫纤,返回自定義的值,避免出現(xiàn)服務(wù)熔斷的情況放钦。

AuthFallBackService.class:是當(dāng)前接口的實現(xiàn)類恭金,其中根據(jù)業(yè)務(wù)需要,在實現(xiàn)方法中定義返回值横腿。
2耿焊、SpringBoot

@EnableTransactionManagement
@SpringBootApplication(exclude = {JacksonAutoConfiguration.class})
@MapperScan("com.herokuCenter.mapper")
@EnableScheduling

public class HerokuCenterApplication {

    public static void main(String[] args) throws IOException {

        String env = StringUtils.isEmpty(System.getenv("ENV")) ? "uat" : System.getenv("ENV");
        env = "uat";
        System.out.println("==========當(dāng)前環(huán)境是:" + env + ", 啟動的配置文件是:application-" + env + ".properties");
        Properties properties = new Properties();
        InputStream in = HerokuCenterApplication.class.getClassLoader().getResourceAsStream("application-" + env + ".properties");
        properties.load(in);

        SpringApplication application = new SpringApplication(HerokuCenterApplication.class);
        application.setDefaultProperties(properties);
        application.run(args);
    }

}

@SpringBootApplication
使用該注解實現(xiàn)springboot項目的自動裝配以及啟動
3、代碼

public String CreateCouponByDMP() {
//省略部分代碼

        String tableName = isFirst.equals("0") ? batch : promCode;
        try {
            tempCouponMapper.createTableBatch("dmp." + "\"" + tableName + "\"");

            logger.info("dmp." + "\"" + tableName + "\"" + "創(chuàng)建表格成功");
        } catch (Exception e) {
            e.printStackTrace();
            logger.info("dmp." + "\"" + tableName + "\"" + "表格創(chuàng)建失敗");
        }
        logger.info("授權(quán)");
        tempCouponMapper.grantToDMP(dmpPGUserName);
        if (isFirst.equals("0")) {
            Map map = new HashMap();
            map.put("promCode", promCode);
            map.put("isfirst", isFirst);
            map.put("batch", batch);
            map.put("tablename", "dmp." + "\"" + batch + "\"");
            map.put("tablenamepro", "dmp." + "\"" + promCode + "\"");
            Integer selectCount = 0;
            String content = "處理成功";
            try {
                tempCouponMapper.insertTempCouponSec(map);
                selectCount = tempCouponMapper.selectCount("dmp." + "\"" + batch + "\"", batch);
            } catch (Exception e) {
                logger.info("isfirst=0;batch={};promCode={};處理異常", batch, promCode);
                content = "處理異常";
                e.printStackTrace();
            }
            Map<String, Object> map2 = new HashMap<>();
            map2.put("batchId", tempPromotionDefinition.getBatch());
            map2.put("endCouponTime", new Date());
            map2.put("couponCount", selectCount.toString());
            promotionTaskMapper.updateEndCoupon(map2);

            notifyDMP(content, tempPromotionDefinition.getBatch(), promCode, selectCount.toString(), busType, "DMP00", keyType);

            return "更新成功";
        }
        ExecutorService executorService = Executors.newFixedThreadPool(5);
        for (int i = 0; i < threadAmount; i++) {
            logger.info("多線程操作");
            executorService.execute(new InsertThread(threadAmount, tempPromotionDefinition.getBatch(), i * btach, btach, promCode,
                    uuid, Count, total, busType, keyType, systemGuid, isFirst));
        }
        executorService.shutdown();

        while (true) {
            try {
                if (executorService.awaitTermination(5, TimeUnit.SECONDS)) {
                    logger.info("------dmp-------:開始通知");
                    Integer selectCount = tempCouponMapper.selectCount("dmp." + "\"" + promCode + "\"", batch);
                    logger.info("------dmp-------{}", selectCount);
                    Map<String, Object> map = new HashMap<>();
                    map.put("batchId", tempPromotionDefinition.getBatch());
                    map.put("endCouponTime", new Date());
                    map.put("couponCount", selectCount.toString());
                    promotionTaskMapper.updateEndCoupon(map);
                    //創(chuàng)建表
                    notifyDMP("處理成功", tempPromotionDefinition.getBatch(), promCode, selectCount.toString(), busType, "DMP00", keyType);
                    logger.info("------dmp-------:通知成功");
                    memberGroupMapper.createRepeatTable(tempPromotionDefinition.getBatch());
                    memberGroupMapper.delteRepeat(tempPromotionDefinition.getBatch());
                    memberGroupMapper.insertMemberGroupRepeat();
                    break;
                } else {
                    logger.info("線程池中還有線程線程钩杰,請等待。措左。避除。。");
                }
            } catch (Exception e) {
                e.printStackTrace();
            }

        }

        return "券生成成功";

    }

代碼描述
代碼在業(yè)務(wù)上的優(yōu)點:根據(jù)狀態(tài)以及批次動態(tài)的創(chuàng)建表格凉逛,避免大量的數(shù)據(jù)積累后出現(xiàn)更新操作數(shù)據(jù)被鎖從而導(dǎo)致性能低下的情況赏壹,同時也避免第三方在進行拉數(shù)據(jù)的時候進行查詢的操作(創(chuàng)建臨時表格,根據(jù)批次數(shù)據(jù)全部拉闰蚪琛)指蚁。
性能上的優(yōu)點:采用線程池避免線程的重復(fù)構(gòu)建,同時使用shutdown()與awaitTermination(5, TimeUnit.SECONDS)的方法來判斷線程執(zhí)行情況稍坯,以及確定在全部執(zhí)行完成后通知第三方系統(tǒng)進行數(shù)據(jù)的拉取,保證數(shù)據(jù)的完整性瞧哟,同時保證性能。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末咧党,一起剝皮案震驚了整個濱河市陨亡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蛙埂,老刑警劉巖遮糖,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異被辑,居然都是意外死亡,警方通過查閱死者的電腦和手機敬惦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進店門盼理,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人俄删,你說我怎么就攤上這事宏怔。” “怎么了畴椰?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵臊诊,是天一觀的道長。 經(jīng)常有香客問我斜脂,道長抓艳,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任帚戳,我火速辦了婚禮,結(jié)果婚禮上片任,老公的妹妹穿的比我還像新娘偏友。我一直安慰自己,他們只是感情好对供,可當(dāng)我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布位他。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鹅髓。 梳的紋絲不亂的頭發(fā)上舞竿,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天,我揣著相機與錄音窿冯,去河邊找鬼骗奖。 笑死,一個胖子當(dāng)著我的面吹牛靡菇,可吹牛的內(nèi)容都是我干的重归。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼厦凤,長吁一口氣:“原來是場噩夢啊……” “哼鼻吮!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起较鼓,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤椎木,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后博烂,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體香椎,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年禽篱,在試婚紗的時候發(fā)現(xiàn)自己被綠了畜伐。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡躺率,死狀恐怖玛界,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情悼吱,我是刑警寧澤慎框,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站后添,受9級特大地震影響笨枯,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜遇西,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一馅精、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧努溃,春花似錦硫嘶、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至第队,卻和暖如春哮塞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背凳谦。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工忆畅, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尸执。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓家凯,卻偏偏與公主長得像,于是被迫代替她去往敵國和親如失。 傳聞我的和親對象是個殘疾皇子绊诲,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,927評論 2 355