init
This commit is contained in:
		@@ -0,0 +1,40 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
 | 
			
		||||
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 | 
			
		||||
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 | 
			
		||||
    <parent>
 | 
			
		||||
        <artifactId>sentinel-demo</artifactId>
 | 
			
		||||
        <groupId>com.alibaba.csp</groupId>
 | 
			
		||||
        <version>1.8.3</version>
 | 
			
		||||
    </parent>
 | 
			
		||||
    <modelVersion>4.0.0</modelVersion>
 | 
			
		||||
 | 
			
		||||
    <artifactId>sentinel-demo-nacos-datasource</artifactId>
 | 
			
		||||
 | 
			
		||||
    <dependencies>
 | 
			
		||||
        <dependency>
 | 
			
		||||
            <groupId>com.alibaba.csp</groupId>
 | 
			
		||||
            <artifactId>sentinel-core</artifactId>
 | 
			
		||||
        </dependency>
 | 
			
		||||
        <dependency>
 | 
			
		||||
            <groupId>com.alibaba.csp</groupId>
 | 
			
		||||
            <artifactId>sentinel-datasource-extension</artifactId>
 | 
			
		||||
        </dependency>
 | 
			
		||||
        <dependency>
 | 
			
		||||
            <groupId>com.alibaba.csp</groupId>
 | 
			
		||||
            <artifactId>sentinel-datasource-nacos</artifactId>
 | 
			
		||||
        </dependency>
 | 
			
		||||
 | 
			
		||||
        <dependency>
 | 
			
		||||
            <groupId>com.alibaba</groupId>
 | 
			
		||||
            <artifactId>fastjson</artifactId>
 | 
			
		||||
        </dependency>
 | 
			
		||||
 | 
			
		||||
        <dependency>
 | 
			
		||||
            <groupId>ch.qos.logback</groupId>
 | 
			
		||||
            <artifactId>logback-classic</artifactId>
 | 
			
		||||
            <version>1.2.3</version>
 | 
			
		||||
        </dependency>
 | 
			
		||||
    </dependencies>
 | 
			
		||||
 | 
			
		||||
</project>
 | 
			
		||||
@@ -0,0 +1,139 @@
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright 1999-2018 Alibaba Group Holding Ltd.
 | 
			
		||||
 *
 | 
			
		||||
 * Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
 * you may not use this file except in compliance with the License.
 | 
			
		||||
 * You may obtain a copy of the License at
 | 
			
		||||
 *
 | 
			
		||||
 *      http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 *
 | 
			
		||||
 * Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 * distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 * See the License for the specific language governing permissions and
 | 
			
		||||
 * limitations under the License.
 | 
			
		||||
 */
 | 
			
		||||
package com.alibaba.csp.sentinel.demo.datasource.nacos;
 | 
			
		||||
 | 
			
		||||
import java.util.Random;
 | 
			
		||||
import java.util.concurrent.TimeUnit;
 | 
			
		||||
import java.util.concurrent.atomic.AtomicInteger;
 | 
			
		||||
 | 
			
		||||
import com.alibaba.csp.sentinel.Entry;
 | 
			
		||||
import com.alibaba.csp.sentinel.SphU;
 | 
			
		||||
import com.alibaba.csp.sentinel.slots.block.BlockException;
 | 
			
		||||
import com.alibaba.csp.sentinel.util.TimeUtil;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Flow QPS runner.
 | 
			
		||||
 *
 | 
			
		||||
 * @author Carpenter Lee
 | 
			
		||||
 * @author Eric Zhao
 | 
			
		||||
 */
 | 
			
		||||
class FlowQpsRunner {
 | 
			
		||||
 | 
			
		||||
    private final String resourceName;
 | 
			
		||||
    private final int threadCount;
 | 
			
		||||
    private int seconds;
 | 
			
		||||
 | 
			
		||||
    public FlowQpsRunner(String resourceName, int threadCount, int seconds) {
 | 
			
		||||
        this.resourceName = resourceName;
 | 
			
		||||
        this.threadCount = threadCount;
 | 
			
		||||
        this.seconds = seconds;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private final AtomicInteger pass = new AtomicInteger();
 | 
			
		||||
    private final AtomicInteger block = new AtomicInteger();
 | 
			
		||||
    private final AtomicInteger total = new AtomicInteger();
 | 
			
		||||
 | 
			
		||||
    private volatile boolean stop = false;
 | 
			
		||||
 | 
			
		||||
    public void simulateTraffic() {
 | 
			
		||||
        for (int i = 0; i < threadCount; i++) {
 | 
			
		||||
            Thread t = new Thread(new RunTask());
 | 
			
		||||
            t.setName("simulate-traffic-Task");
 | 
			
		||||
            t.start();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void tick() {
 | 
			
		||||
        Thread timer = new Thread(new TimerTask());
 | 
			
		||||
        timer.setName("sentinel-timer-task");
 | 
			
		||||
        timer.start();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    final class RunTask implements Runnable {
 | 
			
		||||
        @Override
 | 
			
		||||
        public void run() {
 | 
			
		||||
            while (!stop) {
 | 
			
		||||
                Entry entry = null;
 | 
			
		||||
 | 
			
		||||
                try {
 | 
			
		||||
                    entry = SphU.entry(resourceName);
 | 
			
		||||
                    // token acquired, means pass
 | 
			
		||||
                    pass.addAndGet(1);
 | 
			
		||||
                } catch (BlockException e1) {
 | 
			
		||||
                    block.incrementAndGet();
 | 
			
		||||
                } catch (Exception e2) {
 | 
			
		||||
                    // biz exception
 | 
			
		||||
                } finally {
 | 
			
		||||
                    total.incrementAndGet();
 | 
			
		||||
                    if (entry != null) {
 | 
			
		||||
                        entry.exit();
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                Random random2 = new Random();
 | 
			
		||||
                try {
 | 
			
		||||
                    TimeUnit.MILLISECONDS.sleep(random2.nextInt(50));
 | 
			
		||||
                } catch (InterruptedException e) {
 | 
			
		||||
                    // ignore
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    final class TimerTask implements Runnable {
 | 
			
		||||
        @Override
 | 
			
		||||
        public void run() {
 | 
			
		||||
            long start = System.currentTimeMillis();
 | 
			
		||||
            System.out.println("begin to statistic!!!");
 | 
			
		||||
 | 
			
		||||
            long oldTotal = 0;
 | 
			
		||||
            long oldPass = 0;
 | 
			
		||||
            long oldBlock = 0;
 | 
			
		||||
            while (!stop) {
 | 
			
		||||
                try {
 | 
			
		||||
                    TimeUnit.SECONDS.sleep(1);
 | 
			
		||||
                } catch (InterruptedException e) {
 | 
			
		||||
                }
 | 
			
		||||
                long globalTotal = total.get();
 | 
			
		||||
                long oneSecondTotal = globalTotal - oldTotal;
 | 
			
		||||
                oldTotal = globalTotal;
 | 
			
		||||
 | 
			
		||||
                long globalPass = pass.get();
 | 
			
		||||
                long oneSecondPass = globalPass - oldPass;
 | 
			
		||||
                oldPass = globalPass;
 | 
			
		||||
 | 
			
		||||
                long globalBlock = block.get();
 | 
			
		||||
                long oneSecondBlock = globalBlock - oldBlock;
 | 
			
		||||
                oldBlock = globalBlock;
 | 
			
		||||
 | 
			
		||||
                System.out.println(seconds + " send qps is: " + oneSecondTotal);
 | 
			
		||||
                System.out.println(TimeUtil.currentTimeMillis() + ", total:" + oneSecondTotal
 | 
			
		||||
                    + ", pass:" + oneSecondPass
 | 
			
		||||
                    + ", block:" + oneSecondBlock);
 | 
			
		||||
 | 
			
		||||
                if (seconds-- <= 0) {
 | 
			
		||||
                    stop = true;
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            long cost = System.currentTimeMillis() - start;
 | 
			
		||||
            System.out.println("time cost: " + cost + " ms");
 | 
			
		||||
            System.out.println("total:" + total.get() + ", pass:" + pass.get()
 | 
			
		||||
                + ", block:" + block.get());
 | 
			
		||||
            System.exit(0);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -0,0 +1,45 @@
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright 1999-2018 Alibaba Group Holding Ltd.
 | 
			
		||||
 *
 | 
			
		||||
 * Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
 * you may not use this file except in compliance with the License.
 | 
			
		||||
 * You may obtain a copy of the License at
 | 
			
		||||
 *
 | 
			
		||||
 *      http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 *
 | 
			
		||||
 * Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 * distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 * See the License for the specific language governing permissions and
 | 
			
		||||
 * limitations under the License.
 | 
			
		||||
 */
 | 
			
		||||
package com.alibaba.csp.sentinel.demo.datasource.nacos;
 | 
			
		||||
 | 
			
		||||
import com.alibaba.nacos.api.NacosFactory;
 | 
			
		||||
import com.alibaba.nacos.api.config.ConfigService;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Nacos config sender for demo.
 | 
			
		||||
 *
 | 
			
		||||
 * @author Eric Zhao
 | 
			
		||||
 */
 | 
			
		||||
public class NacosConfigSender {
 | 
			
		||||
 | 
			
		||||
    public static void main(String[] args) throws Exception {
 | 
			
		||||
        final String remoteAddress = "localhost:8848";
 | 
			
		||||
        final String groupId = "Sentinel_Demo";
 | 
			
		||||
        final String dataId = "com.alibaba.csp.sentinel.demo.flow.rule";
 | 
			
		||||
        final String rule = "[\n"
 | 
			
		||||
            + "  {\n"
 | 
			
		||||
            + "    \"resource\": \"TestResource\",\n"
 | 
			
		||||
            + "    \"controlBehavior\": 0,\n"
 | 
			
		||||
            + "    \"count\": 5.0,\n"
 | 
			
		||||
            + "    \"grade\": 1,\n"
 | 
			
		||||
            + "    \"limitApp\": \"default\",\n"
 | 
			
		||||
            + "    \"strategy\": 0\n"
 | 
			
		||||
            + "  }\n"
 | 
			
		||||
            + "]";
 | 
			
		||||
        ConfigService configService = NacosFactory.createConfigService(remoteAddress);
 | 
			
		||||
        System.out.println(configService.publishConfig(dataId, groupId, rule));
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -0,0 +1,81 @@
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright 1999-2018 Alibaba Group Holding Ltd.
 | 
			
		||||
 *
 | 
			
		||||
 * Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
 * you may not use this file except in compliance with the License.
 | 
			
		||||
 * You may obtain a copy of the License at
 | 
			
		||||
 *
 | 
			
		||||
 *      http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 *
 | 
			
		||||
 * Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 * distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 * See the License for the specific language governing permissions and
 | 
			
		||||
 * limitations under the License.
 | 
			
		||||
 */
 | 
			
		||||
package com.alibaba.csp.sentinel.demo.datasource.nacos;
 | 
			
		||||
 | 
			
		||||
import java.util.List;
 | 
			
		||||
import java.util.Properties;
 | 
			
		||||
 | 
			
		||||
import com.alibaba.csp.sentinel.datasource.ReadableDataSource;
 | 
			
		||||
import com.alibaba.csp.sentinel.datasource.nacos.NacosDataSource;
 | 
			
		||||
import com.alibaba.csp.sentinel.slots.block.flow.FlowRule;
 | 
			
		||||
import com.alibaba.csp.sentinel.slots.block.flow.FlowRuleManager;
 | 
			
		||||
import com.alibaba.fastjson.JSON;
 | 
			
		||||
import com.alibaba.fastjson.TypeReference;
 | 
			
		||||
import com.alibaba.nacos.api.PropertyKeyConst;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * This demo demonstrates how to use Nacos as the data source of Sentinel rules.
 | 
			
		||||
 * Before you start, you need to start a Nacos server in local first, and then
 | 
			
		||||
 * use {@link NacosConfigSender} to publish initial rule configuration to Nacos.
 | 
			
		||||
 *
 | 
			
		||||
 * @author Eric Zhao
 | 
			
		||||
 */
 | 
			
		||||
public class NacosDataSourceDemo {
 | 
			
		||||
 | 
			
		||||
    private static final String KEY = "TestResource";
 | 
			
		||||
    // nacos server ip
 | 
			
		||||
    private static final String remoteAddress = "localhost:8848";
 | 
			
		||||
    // nacos group
 | 
			
		||||
    private static final String groupId = "Sentinel_Demo";
 | 
			
		||||
    // nacos dataId
 | 
			
		||||
    private static final String dataId = "com.alibaba.csp.sentinel.demo.flow.rule";
 | 
			
		||||
    // if change to true, should be config NACOS_NAMESPACE_ID
 | 
			
		||||
    private static boolean isDemoNamespace = false;
 | 
			
		||||
    // fill your namespace id,if you want to use namespace. for example: 0f5c7314-4983-4022-ad5a-347de1d1057d,you can get it on nacos's console
 | 
			
		||||
    private static final String NACOS_NAMESPACE_ID = "${namespace}";
 | 
			
		||||
 | 
			
		||||
    public static void main(String[] args) {
 | 
			
		||||
        if (isDemoNamespace) {
 | 
			
		||||
            loadMyNamespaceRules();
 | 
			
		||||
        } else {
 | 
			
		||||
            loadRules();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // Assume we config: resource is `TestResource`, initial QPS threshold is 5.
 | 
			
		||||
        FlowQpsRunner runner = new FlowQpsRunner(KEY, 1, 100);
 | 
			
		||||
        runner.simulateTraffic();
 | 
			
		||||
        runner.tick();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private static void loadRules() {
 | 
			
		||||
        ReadableDataSource<String, List<FlowRule>> flowRuleDataSource = new NacosDataSource<>(remoteAddress, groupId, dataId,
 | 
			
		||||
                source -> JSON.parseObject(source, new TypeReference<List<FlowRule>>() {
 | 
			
		||||
                }));
 | 
			
		||||
        FlowRuleManager.register2Property(flowRuleDataSource.getProperty());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private static void loadMyNamespaceRules() {
 | 
			
		||||
        Properties properties = new Properties();
 | 
			
		||||
        properties.put(PropertyKeyConst.SERVER_ADDR, remoteAddress);
 | 
			
		||||
        properties.put(PropertyKeyConst.NAMESPACE, NACOS_NAMESPACE_ID);
 | 
			
		||||
 | 
			
		||||
        ReadableDataSource<String, List<FlowRule>> flowRuleDataSource = new NacosDataSource<>(properties, groupId, dataId,
 | 
			
		||||
                source -> JSON.parseObject(source, new TypeReference<List<FlowRule>>() {
 | 
			
		||||
                }));
 | 
			
		||||
        FlowRuleManager.register2Property(flowRuleDataSource.getProperty());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user