blob: cda738f7c190db6303fc21abfabb0dbbe136f96d [file] [log] [blame]
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07001/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2014-present Open Networking Laboratory
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Brian O'Connorabafb502014-12-02 22:26:20 -080016package org.onosproject.core.impl;
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070017
18import org.apache.felix.scr.annotations.Activate;
19import org.apache.felix.scr.annotations.Component;
Thomas Vachuska36002e62015-05-19 16:12:29 -070020import org.apache.felix.scr.annotations.Deactivate;
21import org.apache.felix.scr.annotations.Modified;
22import org.apache.felix.scr.annotations.Property;
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070023import org.apache.felix.scr.annotations.Reference;
24import org.apache.felix.scr.annotations.ReferenceCardinality;
25import org.apache.felix.scr.annotations.Service;
Murat Parlakisikdc17f7b2016-01-26 12:08:35 -080026import org.onlab.metrics.MetricsService;
Murat Parlakisik553db172015-04-08 03:29:04 -070027import org.onlab.util.SharedExecutors;
Yuta HIGUCHI45ff2d92017-06-08 16:32:00 -070028import org.onlab.util.SharedScheduledExecutors;
Jian Lid9b5f552016-03-11 18:15:31 -080029import org.onlab.util.Tools;
Thomas Vachuskac65dd712015-11-04 17:19:10 -080030import org.onosproject.app.ApplicationService;
Murat Parlakisik553db172015-04-08 03:29:04 -070031import org.onosproject.cfg.ComponentConfigService;
Brian O'Connorabafb502014-12-02 22:26:20 -080032import org.onosproject.core.ApplicationId;
sangyun-han6d33e802016-08-05 13:36:33 +090033import org.onosproject.app.ApplicationIdStore;
Brian O'Connorabafb502014-12-02 22:26:20 -080034import org.onosproject.core.CoreService;
35import org.onosproject.core.IdBlockStore;
36import org.onosproject.core.IdGenerator;
37import org.onosproject.core.Version;
Thomas Vachuska36002e62015-05-19 16:12:29 -070038import org.onosproject.event.EventDeliveryService;
Murat Parlakisik553db172015-04-08 03:29:04 -070039import org.osgi.service.component.ComponentContext;
Thomas Vachuska8dc1a692015-03-31 01:01:37 -070040import org.slf4j.Logger;
41import org.slf4j.LoggerFactory;
Thomas Vachuska36002e62015-05-19 16:12:29 -070042
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070043import java.io.File;
HIGUCHI Yuta3b3bd1e2015-09-22 16:39:33 -070044import java.io.IOException;
45import java.nio.file.Files;
46import java.nio.file.Path;
47import java.nio.file.Paths;
Murat Parlakisik553db172015-04-08 03:29:04 -070048import java.util.Dictionary;
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070049import java.util.List;
50import java.util.Set;
51
52import static com.google.common.base.Preconditions.checkNotNull;
Changhoon Yoon541ef712015-05-23 17:18:34 +090053import static org.onosproject.security.AppGuard.checkPermission;
Jian Lid9b5f552016-03-11 18:15:31 -080054import static org.onosproject.security.AppPermission.Type.APP_READ;
55import static org.onosproject.security.AppPermission.Type.APP_WRITE;
Changhoon Yoon541ef712015-05-23 17:18:34 +090056
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070057
58/**
59 * Core service implementation.
60 */
Brian O'Connor520c0522014-11-23 23:50:47 -080061@Component(immediate = true)
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070062@Service
63public class CoreManager implements CoreService {
64
Thomas Vachuska8dc1a692015-03-31 01:01:37 -070065 private final Logger log = LoggerFactory.getLogger(getClass());
66
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070067 private static final File VERSION_FILE = new File("../VERSION");
Ray Milkey08b03a92017-05-15 11:26:33 -070068 private static Version version = Version.version("1.11.0-SNAPSHOT");
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070069
70 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
71 protected ApplicationIdStore applicationIdStore;
72
Brian O'Connor520c0522014-11-23 23:50:47 -080073 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
74 protected IdBlockStore idBlockStore;
75
Murat Parlakisik553db172015-04-08 03:29:04 -070076 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
Thomas Vachuskac65dd712015-11-04 17:19:10 -080077 protected ApplicationService appService;
78
79 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
Murat Parlakisik553db172015-04-08 03:29:04 -070080 protected ComponentConfigService cfgService;
81
Thomas Vachuska36002e62015-05-19 16:12:29 -070082 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
83 protected EventDeliveryService eventDeliveryService;
84
Murat Parlakisikdc17f7b2016-01-26 12:08:35 -080085 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
86 protected MetricsService metricsService;
87
Thomas Vachuska36002e62015-05-19 16:12:29 -070088 private static final int DEFAULT_POOL_SIZE = 30;
89 @Property(name = "sharedThreadPoolSize", intValue = DEFAULT_POOL_SIZE,
Murat Parlakisik553db172015-04-08 03:29:04 -070090 label = "Configure shared pool maximum size ")
Thomas Vachuska36002e62015-05-19 16:12:29 -070091 private int sharedThreadPoolSize = DEFAULT_POOL_SIZE;
92
93 private static final int DEFAULT_EVENT_TIME = 2000;
94 @Property(name = "maxEventTimeLimit", intValue = DEFAULT_EVENT_TIME,
95 label = "Maximum number of millis an event sink has to process an event")
96 private int maxEventTimeLimit = DEFAULT_EVENT_TIME;
Murat Parlakisik553db172015-04-08 03:29:04 -070097
Murat Parlakisikdc17f7b2016-01-26 12:08:35 -080098 private static final boolean DEFAULT_PERFORMANCE_CHECK = false;
99 @Property(name = "sharedThreadPerformanceCheck", boolValue = DEFAULT_PERFORMANCE_CHECK,
100 label = "Enable queue performance check on shared pool")
101 private boolean calculatePoolPerformance = DEFAULT_PERFORMANCE_CHECK;
102
103
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700104 @Activate
Thomas Vachuska0666f152016-08-05 12:03:54 -0700105 protected void activate() {
Thomas Vachuska6cba4952015-04-22 12:38:22 -0700106 registerApplication(CORE_APP_NAME);
Murat Parlakisik553db172015-04-08 03:29:04 -0700107 cfgService.registerProperties(getClass());
HIGUCHI Yuta3b3bd1e2015-09-22 16:39:33 -0700108 try {
109 Path path = Paths.get(VERSION_FILE.getPath());
110 List<String> versionLines = Files.readAllLines(path);
111 if (versionLines != null && !versionLines.isEmpty()) {
112 version = Version.version(versionLines.get(0));
113 }
114 } catch (IOException e) {
115 // version file not found, using default
116 log.trace("Version file not found", e);
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700117 }
118 }
119
Murat Parlakisik553db172015-04-08 03:29:04 -0700120 @Deactivate
Thomas Vachuska0666f152016-08-05 12:03:54 -0700121 protected void deactivate() {
Murat Parlakisik553db172015-04-08 03:29:04 -0700122 cfgService.unregisterProperties(getClass(), false);
Thomas Vachuskab0317c62015-04-08 23:58:58 -0700123 SharedExecutors.shutdown();
Yuta HIGUCHI45ff2d92017-06-08 16:32:00 -0700124 SharedScheduledExecutors.shutdown();
Murat Parlakisik553db172015-04-08 03:29:04 -0700125 }
126
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700127 @Override
128 public Version version() {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900129 checkPermission(APP_READ);
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700130 return version;
131 }
132
133 @Override
134 public Set<ApplicationId> getAppIds() {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900135 checkPermission(APP_READ);
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700136 return applicationIdStore.getAppIds();
137 }
138
139 @Override
140 public ApplicationId getAppId(Short id) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900141 checkPermission(APP_READ);
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700142 return applicationIdStore.getAppId(id);
143 }
144
145 @Override
Ray Milkey02479862015-02-17 17:02:19 -0800146 public ApplicationId getAppId(String name) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900147 checkPermission(APP_READ);
Ray Milkey02479862015-02-17 17:02:19 -0800148 return applicationIdStore.getAppId(name);
149 }
150
151
152 @Override
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700153 public ApplicationId registerApplication(String name) {
Heedo Kang4a47a302016-02-29 17:40:23 +0900154 checkPermission(APP_WRITE);
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700155 checkNotNull(name, "Application ID cannot be null");
156 return applicationIdStore.registerApplication(name);
157 }
158
Brian O'Connor520c0522014-11-23 23:50:47 -0800159 @Override
Thomas Vachuskac65dd712015-11-04 17:19:10 -0800160 public ApplicationId registerApplication(String name, Runnable preDeactivate) {
Heedo Kang4a47a302016-02-29 17:40:23 +0900161 checkPermission(APP_WRITE);
Thomas Vachuskac65dd712015-11-04 17:19:10 -0800162 ApplicationId id = registerApplication(name);
163 appService.registerDeactivateHook(id, preDeactivate);
164 return id;
165 }
166
167 @Override
Brian O'Connor520c0522014-11-23 23:50:47 -0800168 public IdGenerator getIdGenerator(String topic) {
Heedo Kang4a47a302016-02-29 17:40:23 +0900169 checkPermission(APP_READ);
Brian O'Connor520c0522014-11-23 23:50:47 -0800170 IdBlockAllocator allocator = new StoreBasedIdBlockAllocator(topic, idBlockStore);
171 return new BlockAllocatorBasedIdGenerator(allocator);
172 }
173
Murat Parlakisik553db172015-04-08 03:29:04 -0700174
175 @Modified
Thomas Vachuska0666f152016-08-05 12:03:54 -0700176 protected void modified(ComponentContext context) {
Murat Parlakisik553db172015-04-08 03:29:04 -0700177 Dictionary<?, ?> properties = context.getProperties();
Jian Lid9b5f552016-03-11 18:15:31 -0800178 Integer poolSize = Tools.getIntegerProperty(properties, "sharedThreadPoolSize");
Murat Parlakisik553db172015-04-08 03:29:04 -0700179
Thomas Vachuska36002e62015-05-19 16:12:29 -0700180 if (poolSize != null && poolSize > 1) {
181 sharedThreadPoolSize = poolSize;
182 SharedExecutors.setPoolSize(sharedThreadPoolSize);
183 } else if (poolSize != null) {
184 log.warn("sharedThreadPoolSize must be greater than 1");
185 }
186
Jian Lid9b5f552016-03-11 18:15:31 -0800187 Integer timeLimit = Tools.getIntegerProperty(properties, "maxEventTimeLimit");
Jonathan Hart943893f2016-04-08 13:38:54 -0700188 if (timeLimit != null && timeLimit >= 0) {
Thomas Vachuska36002e62015-05-19 16:12:29 -0700189 maxEventTimeLimit = timeLimit;
190 eventDeliveryService.setDispatchTimeLimit(maxEventTimeLimit);
191 } else if (timeLimit != null) {
Jonathan Hart943893f2016-04-08 13:38:54 -0700192 log.warn("maxEventTimeLimit must be greater than or equal to 0");
Thomas Vachuska36002e62015-05-19 16:12:29 -0700193 }
194
Jian Lid9b5f552016-03-11 18:15:31 -0800195 Boolean performanceCheck = Tools.isPropertyEnabled(properties, "sharedThreadPerformanceCheck");
Murat Parlakisikdc17f7b2016-01-26 12:08:35 -0800196 if (performanceCheck != null) {
197 calculatePoolPerformance = performanceCheck;
Thomas Vachuska0666f152016-08-05 12:03:54 -0700198 SharedExecutors.setMetricsService(calculatePoolPerformance ? metricsService : null);
Murat Parlakisikdc17f7b2016-01-26 12:08:35 -0800199 }
200
201 log.info("Settings: sharedThreadPoolSize={}, maxEventTimeLimit={}, calculatePoolPerformance={}",
202 sharedThreadPoolSize, maxEventTimeLimit, calculatePoolPerformance);
Thomas Vachuska36002e62015-05-19 16:12:29 -0700203 }
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700204}