分服务器内存

阅读: 评论:0

分服务器内存

分服务器内存

系统需要处理相同逻辑但某种类型不同业务.比如商品,根据不同的分类,加载缓存到不同的服务器,一个服务器只处理某个分类的商品,从而给服务器减轻压力.

####SpringBoot实例(币种兑换交易,根据兑换币种的类型区分服务器):

```java
exchange:
  coinex:
    coinlist:
      - USDC_USDT
      - BTC_USDT
```

获取该配置的币种 TradeProperties.java
```java
@Data
@Component
@ConfigurationProperties(prefix = &#inex")
public class TradeProperties {

    private List<String> coinlist;
}
```

服务启动,加载缓存 TradeDevider.java
```java
@Component
public class TradeDevider implements AfterSpringLoaded {

    @Autowired
    private TradeProperties properties;

    private static Map<String, CoinTrade> tradeMap = new HashMap<String, CoinTrade>();

    private static Map<String, CoinTrade> tradeMapTen = new HashMap<String, CoinTrade>();

    @Override
    public void load() {
        List<String> supportCoins = Coinlist();
        for (String support : supportCoins) {
            //判断当前服务器需要加载的币种缓存
            if (SupportTradeCoin.isSupport(support)) {
                CoinTrade trade = new CoinTrade(support);
                trade.initWhenSpringloaded();
                tradeMap.put(support, trade);
            }
        }
    }

    public static CoinTrade getTrade(String tradeCoin) {
        CoinTrade trade = (tradeCoin);
        if (trade != null) {
            return trade;
        }
        throw new hange_notsupport_coin);
    }
}
```
币种是否支持 SupportTradeCoin.java
```java
public enum SupportTradeCoin {

    USDC_USDT,
    BTC_USDT,
    EOS_USDT,
    ETH_USDT;

    public static boolean isSupport(String supportCoin) {
        try {
            SupportTradeCoin.valueOf(supportCoin);
        } catch (Exception e) {
            return false;
        }
        return true;
    }

}
```
CoinTrade.java的initWhenSpringloaded()实现
```java
public class CoinTrade implements BuyAndSellCacheOperateInterface {

    final CoinBuyCache baseCoinBuy = new CoinBuyCache();

    final CoinSellCache baseCoinSell = new CoinSellCache();


    @Override
    public BaseCoin getBaseCoinBuy() {
        return baseCoinBuy;
    }

    @Override
    public BaseCoin getBaseCoinSell() {
        return baseCoinSell;
    }
}
```

BuyAndSellCacheOperateInterface.java接口
```java
public interface BuyAndSellCacheOperateInterface {
    public BaseCoin getBaseCoinBuy();

    public BaseCoin getBaseCoinSell();

   public String getCoinType();


    public default void initWhenSpringloaded() {
        CoinexServiceImpl impl = (CoinexServiceImpl) Bean(CoinexServiceImpl.class);
        //数据库获取需要加载到缓存中的数据
        Map<String, List<Coinex>> coinexes = AllByType(getCoinType());
        // 增加内存
        addCacheCoinex(coinexes);
    }

    public default void addCacheCoinex(Map<String, List<Coinex>> coinexesMap) {
        synchronized (this) {
            if (null != coinexesMap && coinexesMap.size() > 0) {
                getBaseCoinBuy().(ExchangeConstant.COINEX_TYPE.BUY));
                getBaseCoinSell().(ExchangeConstant.COINEX_TYPE.SELL));
            }
        }
    }
```


```java

public abstract class BaseCoin<T extends Coinex> {
    //缓存 coinexArray
    protected final List<T> coinexArray = new LinkedList<T>();

    /**
      获取缓存
    **/
    public List<T> getCoinex(int size) {
        int coinSize = coinexArray.size();

        List<T> coinexReturn = new ArrayList<T>();
        if (coinSize == 0) {
            return coinexReturn;
        }
        if (coinSize < size) {
            size = coinSize;
        }
        for (int i = 0; i < size; i++) {
            coinexReturn.(i));
        }
        return coinexReturn;
    }
    /**
      添加缓存
    **/
    public void addCoinex(List<T> coinexAdd) {
        if (CollectionUtil.isNotEmpty(coinexAdd)) {
            for (T coinex : coinexAdd) {
                coinexArray.add(coinex);
            }
            Collections.sort(coinexArray);
        }
    }
    /**
      删除缓存
    **/
    public void removeCoinex(List<T> coinexRemove) {
        if (CollectionUtil.isNotEmpty(coinexRemove)) {
            for (T coinex : coinexRemove) {
                ve(coinex);
            }
            Collections.sort(coinexArray);
        }
    }

}
```

```java
public class CoinBuyCache extends BaseCoin<CoinBuy> {

}

public class CoinSellCache extends BaseCoin<CoinBuy> {

}
```

```java
@Data
public class Coinex extends BaseEntity implements Comparable<Coinex> {
......
    /**
    * 类型
    */
    private String type;

   /**
    * 委托价
    */
    private BigDecimal entrustPrice;

    /**
     * 创建时间
     */
    private Date createTime;
......

    @Override
    public int compareTo(Coinex o) {
        if (ExchangeConstant.COINEX_TYPE.BUY.Type())) {
            //根据 价格倒序排序, 时间正序排序
            if (EntrustPrice()EntrustPrice()) > 0) {
                return -1;
            } else if (EntrustPrice()EntrustPrice()) < 0) {
                return 1;
            } else {
                CreateTime()CreateTime());
            }
        }
        if (ExchangeConstant.COINEX_TYPE.SELL.Type())) {
            //根据价格,正序排序, 时间正序排序
            if (EntrustPrice()EntrustPrice()) < 0) {
                return -1;
            } else if (EntrustPrice()EntrustPrice()) > 0) {
                return 1;
            } else {
                CreateTime()CreateTime());
            }
        }

        return 0;
    }
}

public class CoinBuy extends Coinex {

    @Override
    public int compareTo(Coinex o) {
        return 0;
    }
}

public class CoinSell extends Coinex {

    @Override
    public int compareTo(Coinex o) {
       return 0;
    }
}
```

实现类
```java
@Service
@Slf4j
public class CoinexServiceImpl extends ServiceImpl<CoinexMapper, Coinex> implements CoinexService {

......
@Override
    public int addCache(Coinex coinex) {
        try {
            CoinTrade trade = CoinType());
            List<Coinex> coinexList = new ArrayList<>();
            coinexList.add(coinex);
            if (ExchangeConstant.COINEX_TYPE.BUY.Type())) {
                BaseCoinBuy().addCoinex(coinexList);
            }
            if (ExchangeConstant.COINEX_TYPE.SELL.Type())) {
                BaseCoinSell().addCoinex(coinexList);
            }
        } catch (LFException e) {
            //判断是否支持该币种,不支持则广播给其他服务器
            if (e.getCode().hange_Code())) {
                String mqEvent = ExchangeConstant.MQEvent.LOADADDCOIN;
                MQMessage message = new MQMessage(mqEvent, coinex);
                RabbitService rabbitService = (RabbitService) Bean(RabbitService.class);
                rabbitService.send(Excharge.brodcast, "plat-exchange", message);
                log.warn("添加缓存: 不支持改币种,广播给其他服务器", e);
                return 1;
            } else {
                log.Message(), e);
            }
        } catch (Exception e) {
            ("处理异常", e);
            return 0;
        }
        return 1;
    }
}
```


 

本文发布于:2024-01-28 02:57:49,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/17063818714280.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:内存   服务器
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23