-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathconfig.py
326 lines (271 loc) · 10.4 KB
/
config.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
"""This module contains all configuration information used to run simulations.
Overview
========
This reference configuration file is divided into two parts.
The first part lists generic simulation parameters such as number of processes
to use, logging configuration and so on.
The second part builds an "experiment queue", i.e. a queue of configuration
parameters each representing one single experiment.
Each element of the queue must be an instance of the icarus.util.Tree class,
which is an object modelling a tree of hierarchically organized configuration
parameters. Alternatively nested dictionaries can be used instead of trees. In
this case Icarus will convert them to trees at runtime. It is however suggested
to use Tree objects because they provide methods that simplify the definition
of experiments.
Experiment definition syntax
============================
This figure below represents the parameter structure accepted by Icarus:
|
|--- topology
| |----- name
| |----- topology arg 1
| |----- topology arg 2
| |----- ..............
| |----- topology arg N
|
|--- workload
| |----- name
| |----- workload arg 1
| |----- workload arg 2
| |----- ..............
| |----- workload arg N
|
|--- cache_placement
| |----- name
| |----- cache_placement arg 1
| |----- cache_placement arg 2
| |----- ......................
| |----- cache_placement arg N
|
|--- content_placement
| |----- name
| |----- content_placement arg 1
| |----- content_placement arg 2
| |----- .......................
| |----- content_placement arg N
|
|--- strategy
| |----- name
| |----- strategy arg 1
| |----- strategy arg 2
| |----- ..............
| |----- strategy arg N
|
|--- cache_policy
| |----- name
| |----- cache_policy arg 1
| |----- cache_policy arg 2
| |----- ..................
| |----- cache_policy arg N
|
Here below are listed all components currently provided by Icarus and lists
all parameters for each of them
topology
--------
Path topology
* name: PATH
* args:
* n: number of nodes
Tree topology
* name: TREE
* args:
* h: height
* k: branching factor
RocketFuel topologies
* name: ROCKET_FUEL
* args:
* asn: ASN of topology selected (see resources/README.md for further info)
* source_ratio: ratio of nodes to which attach a content source
* ext_delay: delay of interdomain links
Internet Topology Zoo topologies
* name: GARR, GEANT, TISCALI, WIDE, GEANT_2, GARR_2, TISCALI_2
* args: None
workload
--------
Stationary Zipf workload
* name: STATIONARY
* args:
* alpha : float, the Zipf alpha parameter
* n_contents: number of content objects
* n_warmup: number of warmup requests
* n_measured: number of measured requests
* rate: requests rate
GlobeTraff workload
* name: GLOBETRAFF
* args:
* reqs_file: the path to a GlobeTraff request file
* contents_file: the path to a GlobeTraff content file
Trace-driven workload
* name: TRACE_DRIVEN
* args:
* reqs_file: the path to the requests file
* contents_file: the path to the contents file
* n_contents: number of content objects
* n_warmup: number of warmup requests
* n_measured: number of measured requests
content_placement
-----------------
Uniform (content uniformly distributed among servers)
* name: UNIFORM
* args: None
cache_placement
---------------
* name:
* UNIFORM -> cache space uniformly spread across caches
* CONSOLIDATED -> cache space consolidated among nodes with top betweenness centrality
* BETWEENNESS_CENTRALITY -> cache space assigned to all candidate nodes proportionally to their betweenness centrality
* DEGREE -> cache space assigned to all candidate nodes proportionally to their degree
* args
* For all:
* network_cache: overall network cache (in number of entries) as fraction of content catalogue
* For CONSOLIDATED
* spread: The fraction of top centrality nodes on which caches are deployed (optional, default: 0.5)
strategy
--------
* name:
* LCE -> Leave Copy Everywhere
* NO_CACHE -> No caching, shorest-path routing
* HR_SYMM -> Symmetric hash-routing
* HR_ASYMM -> Asymmetric hash-routing
* HR_MULTICAST -> Multicast hash-routing
* HR_HYBRID_AM -> Hybrid Asymm-Multicast hash-routing
* HR_HYBRID_SM -> Hybrid Symm-Multicast hash-routing
* CL4M -> Cache less for more
* PROB_CACHE -> ProbCache
* LCD -> Leave Copy Down
* RAND_CHOICE -> Random choice: cache in one random cache on path
* RAND_BERNOULLI -> Random Bernoulli: cache randomly in caches on path
* args:
* For PROB_CACHE
* t_tw : float, optional, default=10. The ProbCache t_tw parameter
* For HR_HYBRID_AM
* max_stretch: float, optional, default=0.2.
The max detour stretch for selecting multicast
cache_policy
------------
* name:
* LRU -> Least Recently Used
* SLRU -> Segmeted Least Recently Used
* LFU -> Least Frequently Used
* NULL -> No cache
* RAND -> Random eviction
* FIFO -> First In First Out
* args:
* For SLRU:
* segments: int, optional, default=2. Number of segments
desc
----
string describing the experiment (used to print on screen progress information)
Further info
============
To get further information about the models implemented in the simulator you
can inspect the source code which is well organized and documented:
* Topology implementations are located in ./icarus/scenarios/topology.py
* Cache placement implementations are located in
./icarus/scenarios/cacheplacement.py
* Caching and routing strategies located in ./icarus/models/strategy.py
* Cache eviction policy implementations are located in ./icarus/models/cache.py
"""
from multiprocessing import cpu_count
from collections import deque
import copy
from icarus.util import Tree
############################## GENERAL SETTINGS ##############################
# Level of logging output
# Available options: DEBUG, INFO, WARNING, ERROR, CRITICAL
LOG_LEVEL = 'INFO'
# If True, executes simulations in parallel using multiple processes
# to take advantage of multicore CPUs
PARALLEL_EXECUTION = True
# Number of processes used to run simulations in parallel.
# This option is ignored if PARALLEL_EXECUTION = False
N_PROCESSES = cpu_count()
# Granularity of caching.
# Currently, only OBJECT is supported
CACHING_GRANULARITY = 'OBJECT'
# Format in which results are saved.
# Result readers and writers are located in module ./icarus/results/readwrite.py
# Currently only PICKLE is supported
RESULTS_FORMAT = 'PICKLE'
# Number of times each experiment is replicated
# This is necessary for extracting confidence interval of selected metrics
N_REPLICATIONS = 3
# List of metrics to be measured in the experiments
# The implementation of data collectors are located in ./icaurs/execution/collectors.py
# Remove collectors not needed
DATA_COLLECTORS = [
'CACHE_HIT_RATIO', # Measure cache hit ratio
'LATENCY', # Measure request and response latency (based on static link delays)
'LINK_LOAD', # Measure link loads
'PATH_STRETCH', # Measure path stretch
]
########################## EXPERIMENTS CONFIGURATION ##########################
# Default experiment values, i.e. values shared by all experiments
# Number of content objects
N_CONTENTS = 3*10**5
# Number of content requests generated to pre-populate the caches
# These requests are not logged
N_WARMUP_REQUESTS = 3*10**5
# Number of content requests that are measured after warmup
N_MEASURED_REQUESTS = 6*10**5
# Number of requests per second (over the whole network)
REQ_RATE = 1.0
# Cache eviction policy
CACHE_POLICY = 'LRU'
# Zipf alpha parameter, remove parameters not needed
ALPHA = [0.6, 0.8, 1.0]
# Total size of network cache as a fraction of content population
# Remove sizes not needed
NETWORK_CACHE = [0.004, 0.002]
# List of topologies tested
# Topology implementations are located in ./icarus/scenarios/topology.py
# Remove topologies not needed
TOPOLOGIES = [
'GEANT',
'WIDE',
'GARR',
'TISCALI',
]
# List of caching and routing strategies
# The code is located in ./icarus/models/strategy.py
# Remove strategies not needed
STRATEGIES = [
'LCE', # Leave Copy Everywhere
'NO_CACHE', # No caching, shortest-path routing
'HR_SYMM', # Symmetric hash-routing
'HR_ASYMM', # Asymmetric hash-routing
'HR_MULTICAST', # Multicast hash-routing
'HR_HYBRID_AM', # Hybrid Asymm-Multicast hash-routing
'HR_HYBRID_SM', # Hybrid Symm-Multicast hash-routing
'CL4M', # Cache less for more
'PROB_CACHE', # ProbCache
'LCD', # Leave Copy Down
'RAND_CHOICE', # Random choice: cache in one random cache on path
'RAND_BERNOULLI', # Random Bernoulli: cache randomly in caches on path
]
# Instantiate experiment queue
EXPERIMENT_QUEUE = deque()
# Build a default experiment configuration which is going to be used by all
# experiments of the campaign
default = Tree()
default['workload'] = {'name': 'STATIONARY',
'n_contents': N_CONTENTS,
'n_warmup': N_WARMUP_REQUESTS,
'n_measured': N_MEASURED_REQUESTS,
'rate': REQ_RATE}
default['cache_placement']['name'] = 'UNIFORM'
default['content_placement']['name'] = 'UNIFORM'
default['cache_policy']['name'] = CACHE_POLICY
# Create experiments multiplexing all desired parameters
for alpha in ALPHA:
for strategy in STRATEGIES:
for topology in TOPOLOGIES:
for network_cache in NETWORK_CACHE:
experiment = copy.deepcopy(default)
experiment['workload']['alpha'] = alpha
experiment['strategy']['name'] = strategy
experiment['topology']['name'] = topology
experiment['cache_placement']['network_cache'] = network_cache
experiment['desc'] = "Alpha: %s, strategy: %s, topology: %s, network cache: %s" \
% (str(alpha), strategy, topology, str(network_cache))
EXPERIMENT_QUEUE.append(experiment)