📄 server.java
字号:
/**
* Copyright (C) 2006, Laboratorio di Valutazione delle Prestazioni - Politecnico di Milano
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
package jmt.engine.NodeSections;
import jmt.engine.NetStrategies.ServiceStrategy;
import jmt.engine.QueueNet.*;
/**
* This class implements a multi-class, single/multi server service.
* Every class has a specific distribution and a own set of statistical
* parameters.
* A server service remains busy while processing one or more jobs.
* @author Francesco Radaelli, Stefano Omini
*/
public class Server extends ServiceSection {
public static final boolean DEBUG = false;
/** Property Identifier: Busy counter. */
public static final int PROPERTY_ID_BUSY_COUNTER = 0x0101;
/** Property Identifier: Max jobs. */
public static final int PROPERTY_ID_MAX_JOBS = 0x0102;
/** Property Identifier: Visits per class. */
public static final int PROPERTY_ID_VISITS_PER_CLASS = 0x0103;
/** Property Identifier: Service strategy. */
public static final int PROPERTY_ID_SERVICE_STRATEGY = 0x0104;
//TODO: o si usano per correggere i response time (R=r*v) oppure toglierle!!
private int numberOfVisitsPerClass[];
private int busyCounter, numberOfServers;
//private JobInfoList tempJobsList;
private ServiceStrategy serviceStrategy[];
/** Creates a new instance of Server.
* @param numberOfVisitsPerClass Number of job visits per class: if null
* the server will be single visit.
* @param serverNumber Number of jobs which can be served simultaneously.
* @param serviceStrategy Array of service strategies, one per class.
* @throws jmt.common.exception.NetException
*/
public Server(Integer serverNumber, Integer numberOfVisitsPerClass[],
ServiceStrategy serviceStrategy[]) throws jmt.common.exception.NetException {
//numberOfVisitsPerClass is null
if (numberOfVisitsPerClass == null) {
this.serviceStrategy = serviceStrategy;
this.numberOfVisitsPerClass = null;
busyCounter = 0;
this.numberOfServers = serverNumber.intValue();
} else {
//else creates an array of int & then use the same cosntructor
int[] nVisits = new int[numberOfVisitsPerClass.length];
for (int i = 0; i < numberOfVisitsPerClass.length; i++) {
nVisits[i] = numberOfVisitsPerClass[i].intValue();
}
this.serviceStrategy = serviceStrategy;
this.numberOfVisitsPerClass = nVisits;
busyCounter = 0;
this.numberOfServers = serverNumber.intValue();
}
}
/** Creates a new instance of Server.
* @param serverNumber Number of jobs which can be served simultaneously.
* @param numberOfVisitsPerClass Number of job visits per class: if null
* the server will be single visit.
* @param serviceStrategy Array of service strategies, one per class.
* @throws jmt.common.exception.NetException
*/
public Server(int serverNumber, int numberOfVisitsPerClass[],
ServiceStrategy serviceStrategy[]) throws jmt.common.exception.NetException {
this.serviceStrategy = serviceStrategy;
this.numberOfVisitsPerClass = numberOfVisitsPerClass;
busyCounter = 0;
this.numberOfServers = serverNumber;
}
public int getIntSectionProperty(int id) throws jmt.common.exception.NetException {
switch (id) {
case PROPERTY_ID_BUSY_COUNTER:
return busyCounter;
case PROPERTY_ID_MAX_JOBS:
return numberOfServers;
default:
return super.getIntSectionProperty(id);
}
}
public int getIntSectionProperty(int id, JobClass jobClass) throws jmt.common.exception.NetException {
switch (id) {
case PROPERTY_ID_VISITS_PER_CLASS:
return numberOfVisitsPerClass[jobClass.getId()];
default:
return super.getIntSectionProperty(id, jobClass);
}
}
public Object getObject(int id, JobClass jobClass) throws jmt.common.exception.NetException {
switch (id) {
case PROPERTY_ID_SERVICE_STRATEGY:
return serviceStrategy[jobClass.getId()];
default:
return super.getObject(id);
}
}
public Object getObject(int id) throws jmt.common.exception.NetException {
switch (id) {
case PROPERTY_ID_SERVICE_STRATEGY:
return serviceStrategy;
default:
return super.getObject(id);
}
}
protected void nodeLinked(NetNode node) {
//if (numberOfVisitsPerClass != null)
// tempJobsList = new JobInfoList(getJobClasses().size(), true);
}
/*
protected int process(NetMessage message) throws jmt.common.exception.NetException {
int c;
Job job;
double serviceTime;
switch (message.getEvent()) {
case NetEvent.EVENT_ACK:
//EVENT_ACK
//If there are no jobs in the service section, message is not processed.
//Otherwise an ack is sent backward to the input section and
//the counter of jobs in service is decreased.
if (busyCounter == 0) {
//it wasn't waiting for any job
return NodeSection.MSG_NOT_PROCESSED;
}
// Sends a request to the input section
sendBackward(NetEvent.EVENT_ACK, message.getJob(), 0.0);
//log.write(NetLog.LEVEL_ALL, message.getJob(), this, NetLog.ACK_JOB);
busyCounter--;
break;
case NetEvent.EVENT_JOB:
//EVENT_JOB
//If the message has been sent by the server itself and if the
//job is single visit, then the job is forwarded. Otherwise, if
//the job is multi visit the number of visits done and requested
//is checked through a JobVisitsInfo object (created during the
//first visit). If all visits have been completed, the job is
//forwarded, otherwise it's sent backward to input section
//for further visits.
//
//If the message has been sent by another section, the server, if
//is not completely busy, sends to itself a message containing the
//job and with delay equal to the service time calculated using
//the service strategy.
//The counter of jobs in service is increased and, if further service
//capacity is left, an ack is sent to the input section.
// Gets the job from the message
job = message.getJob();
//----ZERO SERVICE TIME: properties setup-----//
//NEW
//@author Stefano Omini
//first of all check if this job must be tunnelled (because the
//corresponding jobClass has a zero service time distribution)
if (job.TunnelThisJob()) {
//the job must be immediately forwarded to output section
job.setTunnelThisJob(false);
sendForward(job, 0.0);
//log.write(NetLog.LEVEL_DEBUG, job, this, NetLog.JOB_OUT);
return MSG_PROCESSED;
//the job forwarded is not a "normal" job, but a job whose class has a
//zero service time strategy
//in this case do not send any ack backward, otherwise other jobs
//would be sent by the queue (even if the server is already busy!!)
//WARNING: the service section won't receive from
//the output section any ack for the tunnelled job
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -