Articulo IEEE

Descargar como docx, pdf o txt
Descargar como docx, pdf o txt
Está en la página 1de 19

Fundación Universitaria Cafam, Gómez Ceballos María Paula Últimas versiones de sistemas operativos Linux vs Windows

ÚLTIMAS VERSIONES SISTEMAS OPERATIVOS LINUX VS WINDOWS Y SU APLICACIÓN COMERCIAL.

RESUMEN A lo largo de los años y conforme avanza la tecnología hemos visto como dos grandes empresas como lo son
Linux y Windows dominan en parte el mercado de los sistemas operativos y que han ido adaptándose a las necesidades del
consumidor conforme avanzan los tiempo y aún más con la revolución Industria 4.0 se refiere a la cuarta revolución industrial,
con las tres primeras marcadas por la mecanización, la electricidad y las tecnologías de la información, donde cada día es más
importante el uso de las nuevas tecnologías y aumenta la necesidad de contar con sistemas operativos eficientes, autónomos,
agiles que permitan desarrollar las labores cotidianas de forma ágil y sencilla.
Por esta razón en el presente articulo veremos algunas de las opciones de sistemas operativos más recientes de estas
empresas, los beneficios que nos brindan, sus cualidades y atributos.
Con el fin de ser una fuente de información que nos permita encontrar el sistema operativo adecuado a nuestras necesidades.
El desarrollo de sistemas operativos es una actividad que combina diferentes disciplinas, como las matemáticas, la informática
y principalmente la automatización. El importante papel del software libre en la definición de muchas de las herramientas que
usamos hoy en día es el tema central del desarrollo informático actual. El propósito de este trabajo es describir brevemente las
últimas tecnologías para construir diferentes tipos de sistemas operativos y evaluar el uso de una tecnología que ha demostrado
tener una aplicabilidad importante: el desarrollo personalizado. Finalmente, se presentó un caso de estudio en el que se
evaluaron los resultados obtenidos por la aplicación Buildroot para la implementación de la investigación.

ABSTRACT Over the years and as technology advances we have seen how two major companies such as Linux and
Windows dominate part of the operating systems market and have been adapting to consumer needs as time goes by and even
more with the revolution Industry 4. 0 refers to the fourth industrial revolution, with the first three marked by mechanization,
electricity and information technologies, where every day is more important the use of new technologies and increases the need
for efficient, autonomous, agile operating systems that allow to develop daily tasks in an agile and simple way.
For this reason in this article we will see some of the most recent options of operating systems of these companies, the
benefits they offer us, their qualities and attributes.
In order to be a source of information that allows us to find the right operating system for our needs.
The development of operating systems is an activity that combines different disciplines, such as mathematics, computer
science and mainly automation. The important role of free software in the definition of many of the tools we use today is the
central theme of current computer development. The purpose of this paper is to briefly describe the latest technologies for
building different types of operating systems and to evaluate the use of a technology that has shown significant applicability:
custom development. Finally, a case study was presented in which the results obtained by the Buildroot application for the
implementation of the research were evaluated.

INDEX TERMS Ubuntu, Linux, Operating System, Windows, Scripting Languages, Server.

I. INTRODUCTION Además, siempre ha habido dos grupos de usuarios


notables que interactúan con el equipo de
El proceso de construcción de un sistema operativo es un
procesamiento. Información: Las personas que
proceso que involucra una serie de campos del
desarrollan el hardware y las aplicaciones y los
conocimiento, y para satisfacer realmente las necesidades
consumidores de estos productos son Quién los usará
de los usuarios finales, estos campos deben ser
eventualmente. En este marco, cabe destacar el papel del
profundizados. Todo diseño de un sistema operativo está
software libre en entornos académicos y productivos.
principalmente orientado hacia esto y orientado hacia su
acceso El código fuente y el grado de configurabilidad
función. Desde la aparición de los primeros equipos de
hacen de este tipo de software un conjunto completo de
procesamiento de información, el aumento de la
aplicaciones que constituyen un sistema operativo
capacidad informática y de almacenamiento ha
personalizado.
propiciado el desarrollo de sistemas operativos, no solo
en términos de escala o eficiencia, sino también en tipos. Por esto es necesario estructurar el contenido de la
En base a este hecho, el sistema operativo se asocia con información en un cada vez se promueven menos
los componentes de hardware que ejecuta, y en primer soluciones centralizadas cliente/ servidor.
lugar se determinan sus funciones y posibilidades.
WINDOWS.
Comenzamos por LINUX el cual es un sistema operativo
semejante de código abierto desarrollado para computadoras,
Y donde cobran importancia los sistemas operativos de
servidores, mainframes, dispositivos móviles y dispositivos
los cuales hablaremos de los más grandes de la
embebidos. Es compatible con casi todas las principales
actualidad como lo son Linux y Windows, donde se
plataformas informáticas, incluyendo x86, ARM y SPARC,
podrá evidenciar su evolución, avances tecnológicos,
por lo que es uno de los sistemas operativos más soportados.
beneficios y aplicaciones comerciales.
Entre sus ventajas más populares son las de uso gratuito,
Debido a lo anterior, se hace imprescindible comparar
requisitos mínimos de hardware, errores de seguridad
de una forma dinámica, a nivel cualitativo y
poco habituales que tiene soluciones muy sencillas y de
cuantitativo, los sistemas operativos con los que se
rápidas de gestionar además el sistema operativo Linux
cuentan en la actualidad, ya que los documentos
gestiona los recursos de hardware, lanza y gestiona las
encontrados que comparan dichos Sistemas se limitan a
aplicaciones, y proporciona alguna forma de interfaz de
describir elementos (como el costo, la escalabilidad,
usuario. A diferencia con Windows Linux siempre ha
servidor empleado, etc.) que si bien son importantes,
querido mantener una estructura del sistema operativo lo
pueden ser pocos para que el potencial usuario haga su
más sencillas posible para ofrecer un experiencia al
elección de acuerdo con sus necesidades.
usuario cómoda pero se deja en hincapié que al principio
Es por esto por lo que para entrar en contexto y antes de es difícil de manejar dado que el inglés es el idioma
entrar a hablar de las distintas versiones de sistema estándar para las línea de comando y los mensajes de
operativo existentes en la actualidad, es de vital sistema.
importancia abordar la definición del sistema operativo
Por otro lado, podemos hablar de las especificaciones
donde podemos indicar que es el software principal o
del sistema operativo WINDOWS Es un Sistema
conjunto de programas de un sistema informático que
Operativo, que cuenta con un Ambiente Gráfico (GUI)
gestiona los recursos de hardware y provee servicios a
que permite ejecutar programas (aplicaciones) de forma
los programas de aplicación de software, ejecutándose
más fácil y cómoda para el usuario. Microsoft desde
en modo privilegiado respecto de los restantes. 
siempre es ofrecer un sistema operativo de manejo
En las tareas que realiza el sistema operativo, sencillo he de ahí que todos los programas tengan una
especialmente se trata de la gestión que realiza el interfaz gráfica de usuario instituida por eso es muy apto
sistema operativo, especialmente se trata de la gestión para los usuarios principiantes, sus actualizaciones de
de la memoria de nuestro sistema y la carga de sistemas son sencillas y automatizadas. Una de las
diferentes programas, por lo que cada programa tiene mejores ventajas de Windows es la posibilidad de
una prioridad o estructura jerárquica, y depende de ella emplear programas como SharePoint o Exchange uno de
para tener una prioridad superior a la del sistema sus puntos fuertes es la asistencia a largo plazo y
operativo. recursos de nuestro sistema. El programa solución de problemas técnicos por medio de la
bajo es más largo. El sistema operativo también es recuperación del sistema y cabe resaltar todas las
responsable de ejecutar los procesos. Cargamos un herramientas habituales como son las aplicaciones de
programa en la memoria como un proceso, si no se Microsoft.
carga en la memoria, nuestro programa simplemente
Con esto damos una pequeña sinopsis de lo que se verá
"no se ejecuta". Por lo cual hablaremos de las diferentes
en el presente documento.
herramientas de los sistemas operativos de LINUX VS

es la que se utilizará para nuestro análisis. Flichy (2003)


II. RELATED WORKS propone una nueva aproximación para el análisis de la
En esta sección se describen las tendencias de innovación tecnológica. Su principal categoría es el
investigación relacionadas con las distintas versiones de llamado marco de referencia socio-tecnológico, muy
los sistemas operativos aquí analizados. similar al marco técnico o esquema tecnológico propuesto
Marco socio-tecnológico Dentro del desarrollo teórico por Bijker (1987). El marco socio-tecnológico de Flichy
de la COST, Bijker (1987) propuso la noción de marco está conformado por dos partes complementarias: • El
tecnológico. Un marco tecnológico es el marco de marco de la función. • El marco del uso. El marco de la
significados relacionados con una determinada función se relaciona con el uso técnico mientras que el
tecnología, compartido entre varios grupos sociales, que marco del uso con el uso social. Así, define los
guía y da forma al desarrollo de los artefactos. En conocimientos necesarios para «abrir la caja negra» y
palabras de Pinch (1997), « (…) está compuesto por los eventualmente modificar un aparato técnico, es el marco
conceptos y técnicas que una comunidad emplea para la que comparten los diseñadores, técnicos y los usuarios
solución de sus problemas; es una combinación de estratégicos. Mientras que el marco del uso es al mismo
teorías aceptadas, conocimientos tácitos, prácticas de tiempo la capacidad de operar el aparato más los usos
ingeniería, procedimientos especializados de sociales. Flichy (2003) establece una interesante
experimentación y prueba, objetivos y manejo y uso de distinción entre usuarios estratégicos y usuarios tácticos.
prácticas». Este concepto permite establecer un vínculo Los usuarios estratégicos generalmente negocian con los
entre la sociedad en la cual se encuentra inmersa la diseñadores el marco de referencia e intervienen en su
tecnología y su trayectoria de desarrollo (Pinch, 1997, creación, pues pueden especificar las funcionalidades y
pág. 27). Dicha noción ha sido retomada y ampliada por utilidades de las herramientas tecnológicas que quieren
Flichy en su trabajo «L’ innovation technique» (2003), y utilizar. En contraposición, los usuarios tácticos no
negocian el marco de la función, pero pueden influir en
la transformación del marco del uso. Según Flichy, en
una actividad tecnológica llega un momento cuando
ocurre una estabilización del marco de referencia; en ese
momento, todos los actores son tácticos. La mayoría de
los usuarios de las computadoras son usuarios tácticos,
poseen un marco de uso; es decir, saben lo necesario
para operar la computadora, más una serie de usos
sociales, como ver el correo, buscar información, grabar
música, etc. Sin embargo, no saben, en realidad, cómo
funciona la computadora, ni como cambiar o mejorar
sustancialmente su funcionamiento. El marco de la
función son los conocimientos técnicos compartidos por
los diseñadores, técnicos y usuarios estratégicos. Por
tanto, el marco de la función es necesario para «abrir la
caja negra» y modificar el aparato tecnológico. En las
comunidades de desarrollo de GNU/ Linux de todo el
mundo participan muchos usuarios estratégicos,
programadores en su mayoría, quienes conocen el marco
de la función de los sistemas GNU/Linux, incluso
algunos intervienen en su creación y colaboran
activamente en proyectos de desarrollo concretos. Hay
muchas maneras de colaborar, desde probar las últimas
versiones y reportar los posibles errores, hasta aportar
nuevo código e incluso convertirse en desarrollador
oficial. Al igual que una comunidad de científicos, las
comunidades de GNU/ Linux tienen su propio marco de
referencia sociotecnológico que es necesario conocer
para poder formar parte del grupo social relevante. De
acuerdo con esta perspectiva, GNU/ Linux es el
resultado de un proceso multidireccional donde
participan diversos actores e intereses, y, en este sentido,
la construcción social de la tecnología constituye una
aproximación útil para el análisis de su proceso de
innovación tecnológica.

III. PRELIMINARIES
In this section, we formally define the preliminaries used
in our blockchain-based data sharing system among
untrusted parties. We highlight the blockchain network
with side- blocks as part of individual components in addition
to triggers put in place to achieve the system. A brief
outline on the
supposed behavior of cryptographic behavior required for the to execute specified tasks relating to the security of a
system is further described. framework. For the blockchain-based data sharing scheme,

A. BLOCKCHAIN NETWORK
The blockchain is a distributed database that contains an
ordered list of records linked together through chains,
on blocks. Blocks can be defined as individual components
that contain information relating to a particular transaction.
An example of such information can be a log on a single
event (requestor needing data from the system). A blockchain
network maintains a continuous growing list of records which
are immutable. Due to this reason, many systems built on
the blockchain technology achieve secured distribution of
assets among untrusted clients.
For our data sharing among untrusted parties’ system,
the processing and consensus nodes are entirely responsible
for broadcasting blocks into the blockchain network after
processing requests. Forms generated per request are devel-
oped into blocks and later broadcast during the process of
delivering package to a requestor. This action culminates
the completion of a block and permits the broadcast of the
block into the blockchain network. There are multiple threads
of blockchains in the network, identified uniquely using a
requestor’s identity. Threading blocks to their parent blocks
are used to keep a contiguous log of well-ordered logs
devel- oped from requests by different requestors. In
structuring the network this way, we point to the fact that
each block in a particular string represents different
instances of request made. These are indexed and updates by
the smart contracts in a particular child-block are appended
to the parent block as a side-block. The importance of
implementing side-blocks is to maintain an effective log and
efficient fetching of blocks with instances on questioning
and investigation for an occurrence of breach of terms by
the data owner to requestor of the data. Side-blocks
appended to their parent blocks contain reports from the smart
contract reports that are indexed thereby main- taining
accuracy on identical reports with violations stored
concurrently in a smart contract permissions database. The
structure of creating multiple threads for our blockchain
net- work and creating side-blocks on parent blocks,
aggregates
to a comprehensive collection of reports.
As mentioned earlier, a block is developed from a form
created from a request. An entire block is made up of a
single request which spans from when it was made till
when the package is ready for delivery. The processing and
consensus node is responsible for the maintenance of the
blocks and blockchain network. As a matter of fact,
processing and consensus nodes are the only entities with
direct access to the blockchain network. Whilst monitoring
the blocks with side-blocks, nodes alert the system on
breaches to the use of data.

B. CRYPTOGRAPHIC KEYS
Cryptographic keys indicate the sets of keys highlighted
we highlight keys needed to achieve confidentiality for updates the process
trans- actions between systems via untrusted channels.
These keys help to guarantee for a level of security of the
scheme.
For our system, there is the need to adopt cryptographic
primitives for secured transfer of query results between
untrusted data sharing parties to prohibit the influence of
malicious individuals and eavesdroppers on a transaction
between the sharing parties. A description on the
primitives and keys that would best suit the system are
enlightened. The keys include:
• Requestor private key, generated by a requestor and
digitally used to sign requests for data access.
• Requestor public key, generated by a requestor and
sent to data owners authenticator to be used as
verification of requestors identity for data access. The
requestors public key is also used to encrypt a package
to be sent to the requestor by the authenticator.
• Authenticator contract key, key pair generated by
authenticator and attached to smart contract in a package
used for encrypting reports that leave the requestor’s
system to data owner’s system.
For a requestor who wants access to set of records from
a data owner, the requestor generates a key pair (Requestor
private and public keys), stores the private key and shares
the public key with the data owner or other data owner the
requestor might access data from in the future. The
requestor creates, sign using the requestor private key and
send a request to a data owner. On reception, the data
owner con- firms the request by verifying the signature with
the requestor public key.
Results on computations on data requested are tagged on
the data and further processed by data owner by
appropriate entities in the data owner’s system. The data
owner encrypts the whole package (final processed data
to be delivered to requestor) with an authenticator
contract key and shares the package with the requestor. On
reception, the requestor decrypts the encrypted package
and uses the data.
To adequately secure the transfer of actions performed
on the data from the requestor to the data owner, the
reporting of actions generated from the cryptographic
functions flagged on the data should be encrypted using
the authenticator con- tract key tagged to the contracts
generated from the data orig- inator (owner) which would
be sent to a database a secured database.

C. TRIGGERS
Triggers are entities that connect processes between the query
structure and the blockchain environment. The key impor-
tance of implementing triggers for our system is to enable
smart contracts to directly connect from outside the system
to our system since smart contracts cannot directly interact
with structures outside of its environment, thus the blockchain
network. Triggers hold no information and just act as an
intermediary between the query layer and the data
structuring and provenance layer of the system. The trigger
incorporates interfaces internally and externally and
states to and from the query system by the inbound and out- actions to and from the smart-contract
bound smart contracts based on external and internal environment
features of the contract.

IV. DESIGN FORMULATION


A. SYSTEM MODEL
We formulate data sharing mechanism used by the
blockchain-based data sharing among untrusted parties for
data security and provenance. Categories of structures of
the system are displayed in Figure 1 and grouped into four
main layers namely:

FIGURE 1. System design with four main layers and individual


components.

1) User layer: The user layer consists of all the different


classifications of users whose intentions are to access
data from the system for research or other useful pur-
poses. The intent of most users is to help analyse
data for research purposes. Examples of users can be
healthcare organizations such as hospitals, research
institutions as well as universities, individual research
personnel’s and governmental bodies.
2) Data Query layer: The data query layer consists of
sets of querying structures that access, process, for-
ward or respond to queries posed on the system.
Queries on the systems may be requests to access
data from the existing database infrastructure. The
data query layer directly interfaces with the data
structur- ing and provenance layer and has
mechanisms, imple- mented to interpret and translate
actions between the data structuring and provenance
layer and the outside environment (out of the system).
Users directly interact with the query layer for data
requests. Components of the data query layer are.
• Querying system: The query system is
responsible for processing request into a format
desired by the data structuring and provenance
layer. Requestors send a query which is processed
by the query system whose output is a value (data
requested) for the appropriate request. The final
role of the query system is to send a response
based on the request to the requestor.
• Trigger: The trigger is responsible for translating
since smart contracts cannot fully function outside
the blockchain environment.
3) Data Structuring and Provenance layer: Data structur-
ing and provenance layer consist of individual compo-
nents that help process request for access to data from
the existing database infrastructure layer. The layer
additionally performs computations on requested data
and tag data with functionalities that monitor every
action performed on the data. Algorithms and struc-
tures are implemented in the data structuring and prove-
nance layer to report actions which are securely stored
in a database and indexed appropriately triggering an
action on the monitored data if need be. Results of every
action completed are broadcast into an immutable net-
work to guarantee trust-less and fair auditing. Finally,
the layer has a responsibility of authenticating every
request and actions pertaining to data access from the
entire system. The different entities in the data structur-
ing and provenance layer.
• Authenticator: The authenticator is responsible for
verifying the legitimacy of requests sent by
requestors to the data owners’ system. The authen-
ticator generates authenticator contract keys that
are used to encrypt actions from the data in the
user’s environment to the data owner’s system. The
authenticator tags the encryption keys to the entity
responsible for reporting such actions. Addition-
ally, the authenticator encrypts a package which
contains the data requested by the user and is
finally delivered to the appropriate requestor.
• Processing and consensus nodes: The processing
and consensus nodes process forms created for
requests which are later developed into blocks and
broadcast into the blockchain network. In addition,
the consensus node is tasked to create packages
containing the requested data and smart contract to
be delivered to the requestor.
• Smart Contracts: Smart contracts are designed
functions that are activated and executed on the
reception of an action. The smart contracts gen-
erated are embedded with cryptographic keys
enabling contracts to encrypt reports generated
from the activation of actions. The main role of a
smart contract is to identify actions performed on
the sent data and report the data into a database.
Finally, smart contracts revoke access to the vio-
lated data with actions not permissioned on the
data by the requestor.
• Smart Contract Permissioned Database: The smart
contract permissioned database is a report viola-
tion storage and action entity which is activated on
the reception of a violation report by the processing
and consensus nodes for all reports received by the
smart contracts from the requestor. Lists of actions
to be carried out by the data owner on vio- lation
of contracts are stored in the smart contract
permissions database. Receipts are kept for each tures that realizes data sharing by presenting our data access
action activated to adequately provide
consistency for accountability for data forensic and
auditing for future reference.
• Blockchain Network: The blockchain network is
composed of individual block broadcast into a
network and chained together in a chronological
method. The main role of the blockchain net-
work is to maintain a chronologically distributed
immutable database of actions on the delivery and
request of data from the system. The blockchain
also maintains a side-block for individual actions
pertaining to specific data reported by the smart
contracts into the data owner’s system.
4) Existing Database Infrastructure layer: The existing
database infrastructure layer consists of already estab-
lished database systems implemented by individual
parties to accomplish specific tasks. Such database
systems are only accessible by authorized personnel
of such companies since they house sensitive
information which requires secure mechanisms to
adequately pro- tect such sensitive data. For access to
data from such database’s, requested datasets are
passed through sets of computations to desensitize the
data before they are shared.

B. THREAT MODEL AND GOALS


Our threat model is categorized under two levels:
• Data threat level: Data threat level defines violations
from actions entities can perform on data without knowl-
edge of the data owner thereby risking the privacy and
data value of the received by a data user. Such users’
compromise privacy mechanisms imposed in a given
data by desensitizing the acquired data.
• Report swap threat level: A report swap threat level
defines malicious users whose intents are to acquire
data and abuse access rights whilst altering or swap-
ping reports generated by smart contracts tagged to the
data. Such users’ compromise value and privacy for a
requested data.
We aim to achieve the following threat model goals:
• Ensure secure data provenance and auditing by imple-
menting smart contracts which closely monitor all
actions performed on a data thereby exposing the data
threat level for a given malicious user whilst applying
access revoking methods.
• Ensure secured confidentiality of reports by self
retriev- ing keys attached to smart contracts for
encryption, lim- iting the actions of malicious users on
smart contract reports.

V. CONSTRUCTION OF MEDSHARE
In this section, we present a construction of entities and
functions of components necessary for the secured sharing
of data among untrusted parties. We outline designed struc-
system which aims to provide a suitable sharing scheme requestors.
whilst preserving the required security properties of the
blockchain.

A. DESIGN APPROACH
• System setup:
A user sends a request for data access to a sys-
tem. The data request is signed by the user using a
‘‘pre-generated’’ requestor private key. First of all,
the request is received by the query system an entry
point for recording and processing requests. The query
system forwards the request to the data structuring and
prove- nance layer by the triggers since triggers
translate the query (request) into a structure that can be
understood by the data structuring and provenance
layer. The authenti- cator receives the request and
verifies the legitimacy by verifying the signature
using the requestors public key which was generated
and shared before the request was sent. If the signature
is valid, the process is accepted else dropped for invalid
requests.
• Request file:
For a valid request, the authenticator forwards the
request to the processing and consensus nodes where
processing of requests into forms are completed. The
form generated contains a hash of the timestamp of
when the request was received and a hash of the
ID of the requestor. The purpose for the data request
is tagged to the form and then forwarded to the
existing database infrastructure. The existing database
infrastruc- ture receives the form, retrieves the data
and sends the retrieved data to the data structuring
and provenance layer. This is received by the
processing and consensus node and a hash of this
timestamp is concatenated to the existing record of a
hashed timestamp for the request. The processing and
consensus nodes send a request to the smart contract
center for appending sets of rules to the requested
data. A smart contract is generated and tagged to the
form which contains the data indexed to form some
sort of adjacency with the related block.
• Package delivery:
Results of the processed data are then sent to the
authen- ticator to generate an authenticator contract
key and tag the encryption key of this generated set to
the smart contract on the data. The importance of
tagging the smart contracts to the data is to ensure
data auditing and traceability is achieved. The
processing and consensus node process a block based
on the information relating to the request and
broadcasts the block into a blockchain network. The
block forms a part of already existing blocks in
relations to the requestor and is tagged with an
identity to uniquely identify the different blocks in the
network. This is achieved through chronology and
per- fect ordering. The data is encrypted, forming a
package encrypted, and tagged with the ID of the
requestor. The result is forwarded to the query system
through triggers and is finally distributed to respective
Package refers to a completely processed data file Algorithm 1 Smart Contract on Data
along with certain parameters intended for the requestor.
A package contains a data ID, payload (data) and a Require: Initialization of parameters:
smart contract. A package is created from processing getAction, getSensitivity, getRequestorID, getOwnerID,
on received data from the existing database getDataID, getKey, getMetaIndex, retrieve, encrypt,
infrastructure by the consensus nodes. Monitoring of com- ment, report, accessControl.
the lifeline of a package is made effective by attaching Ensure: Setting up functions:
a smart contract to the package. The completion of a func (getSensitivity)
package is culmi- nated by the authenticator by func (getAction)
encrypting the package into a format which can only func (comment)
be readable by a valid and appropriate requestor with func (accessControl)
the right private key. MONITORING OF PACKAGE:
• Auditing and provenance: for func (getAction) == decrypt do
The requestor receives the package and decrypts the func (comment) ← Potray, Data with DataID has
encrypted file using the requestor private key. To ensure been decrypted.
the efficiency of every computation tagged to the retrieve (getKey)
data (smart contracts), decryption of the data should encrypt (comment)
activate the smart contract to retrieve the encryption report (comment ||getRequestorID |getOwnerID)
key tagged to itself and encrypt an action of decrypted end for |
data which is sent to the query system to appropriately if func (getSensitivity) == Low then
forward the report to the data structuring layer to the func (getAction) ← Exemptions on data.
processing and consensus node. The processing and con- ignore
sensus node processes the report into a side-block and else if func (getSensitivity) == Low then
appends the result to the parent block pertaining to that func (getAction) ← Not exemptions on data (violation).
particular data request as part of traces on actions for func (comment) ← Data violation concatenated with
the data. The received report is sent to activate DataID
violation actions that can be applied to the received func (accessControl) ← Revokes access to data.
data from the data owner’s system executed by the retrieve (getKey)
requestor. Success in the acquisition of a report named encrypt (comment)
decrypted data portrays the ability of every action report (comment ||getRequestorID |getOwnerID)
being performed on the data to activate a condition else {func (getSensitivity)
| == High}
specified in the smart contract which generates a func (getAction) ← Violation.
comment to be encrypted and sent to the data owner’s func (comment) ← Data violation concatenated with
system by the smart con- tract. This property is used to DataID
effectively check for data auditability. Again, we stress func (accessControl) ← Revokes access to data.
on the fact that a side- block is created on the parent retrieve (getKey)
block that records actions pertaining to the data encrypt (comment)
reported by the smart contract into the blockchain report (comment ||getRequestorID |getOwnerID)
network. These are all indexed along with the data end if |
stored in the smart contract permissions database.

B. SMART CONTRACTS
Smart contract acts as a finite state machine executing laid We initialize sets of actions that can be applicable to any
down instructions when an action has been activated based on form of data retrieved from the data owner’s system. The
an instance. In this work, we employ smart contracts to basic action sets are read, write, delete, duplicate, move and
report actions completed by a requestor on a data requested copy. These sets of actions when performed on the data would
from a data owner’s system. These enable data owners to trigger the smart contracts to send a report based on the
completely gain assurance and control on data provenance rules established for that particular data. Monitoring of
since the entire lifeline of the sent data would be monitored actions are conveyed in smart contract scripts by a function
in a controlled in a trustworthy environment where the data getAction.
owner needs no assurance of trust from the requestor. The sensitivity of the data is categorized into two lev-
Data reported to the data owner’s system are processed, els which are high and low. These levels of sensitivity are
indexed and broadcast into a blockchain network. In some derived from processing by consensus nodes based on data
instances, reports are reported and stored in a smart contract sets acquired from the database infrastructure. Based on the
permissioned database and indexed based on the data ID of sensitivity of a package, certain actions performed in the
the requested and used data where sets of actions from the data are either exempted from the violations list or serve as
data owner are applicable on the data used by the requestor. violations. For low sensitive level for a data, the data
owner, based on the requested data, can modify the smart
contracts
to ignore actions to avoid reporting of extraneous data from data to the consensus node. The consensus node receives the
being stored. For data with high sensitivity level, the smart duplicated data and creates a package out of it. The package
contract is required to report all actions categorized in the
initialization of getAction to effectively monitor operations
performed on the data, ensuring the detection of breaches
on data. Identities necessary to facilitate the efficient
identifica- tion of unique blocks are classified for a requestor,
data owner and the particular data sent. The advantage of
specifying these in the smart contracts is to create an
efficient means for processing and consensus nodes to
match, process and verify specific blocks. Comments are
generated as statements to describe the actions that were
performed on the data. These are usually violation and
exemption comments. A retrieve statement is paired with a
getAction statement to extract an encryption key to encrypt
comments that would be reported to the data owner’s smart
contract database. An action on encrypt is called to finalize
this process. The action of sending the comments to
processing and consensus nodes is instan- tiated by the
report statement in the smart contract script. The function
accessControl signifies the permissions set by the data
owner that would be carried out in conjunction with the
smart contract permissioned database. On violating the data
contract, access to the data is revoked and pending review
by the data owner who has the choice to re-grant access or
retrieve data back from the requestor.
Embedding statements executable on the reception and
usage of the data by requestor as an assurance of efficient
operation of a smart contract is deemed important. As a matter
of fact, a decryption function activated to generate a report
on decryption of a package will be evident in smart contract
scripts, validating the workability of the smart contract.
Smart contracts on reception of violations revoke the
access of the data for the requestor and sends a report
which is pro- cessed accordingly and permits data owner to
deal with such violations by choice through the smart
contract permissions database. Figure 2 is a brief
description of smart contracts as a finite state machine.

C. DATA PROCESSING AND SHARING BETWEEN EXISTING


DB INFRASTRUCTURE
AND DATA STRUCTURING AND PROVENANCE LAYER
Data sharing between the existing database infrastructure and
the consensus node is critical for the efficient and secured
functioning of the data sharing system among untrusted
par- ticipating entities. Data issued by the existing database
infras- tructure pertaining to a request should maintain
integrity and value inhibiting the ability to render the
system as a contrib- utor to already existing problems. With
such needs, the data sharing methods and processing from
the existing nodes and processing and consensus nodes need
to be carefully designed and structured. Figure 3 describes
data sharing between an existing database infrastructure and
a processing node.
For a verified request, the existing database infrastructure
creates a duplicate of the requested data and assigns the
FIGURE 2. Smart Contract as a Finite State Machine (FSM).

FIGURE 3. Data sharing between Existing DB Infrastructure


and Processing node.

contains a payload and a unique ID of the node responsible


for processing the data along with a unique ID for the
duplicated data received. The processing and consensus
node respon- sible for processing the data verifies the
received data with the form by comparing the data type
with the request. The data is ranked on a scale of being
highly or lowly sensitive by outlining the identifiers and
quasi-identifiers. For a highly sensitive dataset, there is the
need for further anonymisation. These actions performed
on the data are recorded on a form transitioning into a state
of being a block through processing. The result of the
processed data is made available to a second processing
and consensus node to validate the work done by the
first processing node. Assuming validation of the processed
data set is accurate, the processing node returns the data to
the first node.
The processing and consensus node send a request with
an attachment of data sensitivity level to the smart
con- tract generator. The smart contract outputs a script to
the node which is then attached to the current processed
state of the data. Finally, the processing and consensus
node out- puts the result (package) of all processing to the
authenticator. The authenticator encrypts the package with
requestor public key and outputs timestamps to the node.
The processing and consensus node records all timestamps
from processing to enable optimization geared towards
efficiency. In addition,
all actions performed on the data are recorded on the form processing difficult for malicious nodes but efficient and
including the second verifying node. The form is now pro- solvable by verified consensus nodes in the system. Finally,
cessed into a block ready to be broadcast onto the the header consists of a nonce which is an arbitrary number
blockchain network. the consensus nodes generates to modify the header hash in
order to produce a hash below the target difficulty. The block
Algorithm 2 Packagetransaction model. is achieved by the process- ing and consensus nodes. This is
unique to the system to make
DataID: <<ID of payload, excluding signature.>>
NodeID: <<ID of processing node, including
signature.>>
Data:
Hash: <<Hash of payload.>>
Sensitivity: <<Sensitivity of payload.>>
Payload
Verifier Node:
NodeID: <<Node responsible for verifying processed
payload.>>
Contract and Encryption:
Smart Contract: <<Attaching smart contract
to payload.>>
Authenticator Key: <<Tag key to smart contract and
encrypt payload.>>
Timestamp: <<Timestamp of completed processing.>>

D. PARENT BLOCK STRUCTURE


A block is made up of a format which uniquely identifies
the block. This is followed by the block size which contains
the entire size of the block. The next structure is the block
headers. The block header is hashed with sha256(sha256()) as
done in the bitcoin headers. The block header plays a
signifi- cant role in the blockchain network by ensuring
immutability. By changing a block header, an attacker
should be able to change all block headers starting from the
genesis block in order to falsify a blocks record. This
significantly ensures security on the network since there is a
maximum assurance of an impossibility to achieve this task.
This mechanism extensively guarantees data provenance.
For malicious activ- ities, block mismatch will alert the
system of a suspicious ongoing event which triggers data
forensics.
The block header contains the the data version which
indicates the validation rules to follow for a particular data
type. The data version gives account on the properties and
the type of data being accessed. The header is also made up
of the previous blocks hash which is a sha256(sha256())
hash whose function is to ensure that no previous block
header can be changed without changing this blocks header.
The merkle root hash forms part of the header by ensuring
that none of the blocks in the blockchain network can be
modified without modifying the header. This is achieved
by taking the hashes of all the events in the blockchain
network and appending the output to the current block. The
final output is a sha256(sha256()). The header includes a
timestamp of when the block was created. The header
contains target difficulty which is a value of how processing
header is therefore made up of six components.
The block has an action counter whose function is to
record the total number of violation actions applicable on
the accessed data in the entire block. Preceding the action
counter is the transaction which is categorized into two
parts that is, the timestamps and the data. The timestamps
are made up of time to receive request (TTR), time
taken to process request (TTP) and time to send package to
requestor (TTS) whist the data part is made up of the data
owner identity (OID), requestor identity (RID), sensitivity
of data (Dsens), purpose of data request (DRP), processing
node identity (NID) and signature of processing node
(Nsig).
Finally, the structure that defines the entire block is the
block locktime. This is a timestamp that records the last
entry of transaction as well as the closure of a block. When
conditions for this field are met, the block is ready to be
broadcast into the blockchain network. The block locktime
generally signifies the time the block enters the
blockchain. Figure 4 describes structure of the parent
block.

FIGURE 4. Structure of Parent Block.

E. SIDE-BLOCK STRUCTURE
A side block is made up of a format which is derived by
appending a section of the main blocks ID to a
generated ID by consensus node to the side block. This
is followed by the block size which contains the entire size
of the side block. Side blocks also have headers which are
made up of six components. These are the version number
which uniquely identifies the reports used to create the
side block, previous side block hash, merkle root of all
side blocks for a particular parent block, timestamp, target
difference and a nonce. These components have same
properties as their parent block but relates to side blocks.
The side block has an action counter whose function is
to record the violations recorded on a single report.
Preceding the action counter is the transaction which is
made up of the timestamp of violation (TSV), data owner
identity (OID), requestor identity (RID), violation (VLN),
processing node identity (NID) and signature of processing
node (Nsig). The block is timelocked and broadcast unto
the blockchain by appending it to the parent block. Traces
of the report and the data can now be traced. Figure 5
describes structure of the side block.
FIGURE 5. Structure of Side-Block.

TABLE 1. Latency per number of cloud service provider


requests.

FIGURE 6. Latency per number of Cloud Service Provider


requests.

TABLE 2. Comparison between proposed system and other


related systems.

VI. DISCUSSION increase as request per cloud service provider increases. This
This section evaluates the performance of implementing our is due to the trade of between achieving security over low
system on real-case scenarios where cloud service providers latency. The tuple size and pro- cessing and anonymisation
share data among other cloud providers. Monitoring of of data contribute to the increase in latency however,
action applicable on data and data revocation on instances efficiency is achieved in MedShare.
of breaches are implemented as smart contracts in solidity. Table 2 below compares our MeDShare system to other
Algorithm 1 describes the formulation of a smart contract. existing systems and literature presented in this paper.
In simulating interactions on a cloud service provider,
access policies stored as records in blocks and the
permissions database assigns different permissions to users
for available services (access to specific data). Analysis on
request of data, data retrieval and processing (includes the
generating of smart contracts and tagging of smart contracts
on package) and monitoring of actions on data is completed
by using JMeter. Number of active requestors between 5 and
100 users for periods of 2 minutes, 5 minutes, 8 minutes,
10 minutes,
20 minutes and 30 minutes are achieved using JMeter.
Vulnerabilities in MedShare are detected via access control
violations on accessed data which serves as threats to the
MedShare system. Vulnerability analysis is achieved if
Med- Share can detect any inconsistencies and violations
under substantial amounts of usage load. The algorithms in
Med- Share should be able to detect all attacks based on the
number of users thus, number of simulated attacks
corresponds to the number of users simulated in MedShare
data request.
Latency in MedShare has been evaluated by analysing
the time taken to deliver a package after a request has been
sent. This includes all steps required to process a request by
all entities in the MedShare system. The latency for
MedShare is represented in table 1 and Figure 6. An
important observation on the latency is its considerable
With the various metrics derived from the carefully
analogy of data usage and data accumulation, a conclusion
can be drawn that MedShare as compared to the systems
presented has greater advantages.

VII. CONCLUSION
Data sharing and collaboration via cloud service
providers is a stronghold with the increasing advancement
of modern technologies driving today’s society. The
demand of pattern recognition and big data analysis forms
a key component in this advancement as new remedies are
developed from the analysis of medical data. Several
methods and mechanisms have been put in place to
regulate the flow of data from point(s) to point(s) as
medical data in the hands of malicious entities can cause
severe unthinkable damages on all parties related directly
or indirectly to the data.
In this paper we design a data sharing model between
cloud service providers using the blockchain. The design
employs the use of smart contracts and an access control
mechanism to effectively trace the behaviour of the data as
well as revoke access to violated rules and permissions on
data. We analyse the performance of our system as well as
compare with current cutting-edge solutions to data
sharing among cloud service providers. By implementing
the pro- posed model, cloud service providers will be able
to securely achieve data provenance and auditing whilst
sharing medical data among other cloud service providers
as well as entities such as research and medical institutions
without any risk on data privacy.
REFERENCES science from the Kwame Nkrumah
University of Science and Technology,
Bijker, W., Hughes, T., y Pinch, T. 1987. The Social Ghana, in 2014. He is currently
Construction of Technological Systems: New pursuing the mas- ter’s degree in
Directions in the Sociology and History of computer science and technology with
Technology. MIT Press, Cambridge. the University of Science and
Pinch, T. 1997. La construcción social de la Technology of China. His current
tecnología: una revisión. Innovación tecnológica y research includes blockchain
technology and big data security.
procesos culturales: Nuevas perspectivas teóricas, 20–
38. Universidad Autónoma de México - Fondo de
Cultura Económica, México.
JIANBIN GAO received the Ph.D.
degree in computer science from the
University of Elec- tronic Science and
Technology of China (UESTC) in
2012. He was a Visiting Scholar with
the Uni- versity of Pennsylvania,
QI XIA received the B.Sc., M.Sc., and Philadelphia, PA, USA, from 2009 to
Ph.D. degrees in computer science 2011. He is currently an Associate
from the Univer- sity of Electronic Professor with UESTC.
Science and Technology of China
(UESTC) in 2002, 2006, and 2010,
respec- tively. She was a Visiting
Scholar with the Uni- versity of
Pennsylvania, Philadelphia, PA, USA,
from 2013 to 2014 and has published
over twenty papers. She is the PI of
the National Key Research and
Development Program of China in
Cyber Security. She is the Vice Dean
of the Center for
Cyber Security and currently an Associate Professor with
UESTC. She won the National Scientific and
Technological Progress Second Prize in 2012.

EMMANUEL BOATENG SIFAH


received the B.Sc. degree in
telecommunications engineer- ing
from Ghana Technology University
College, Ghana, in 2014, and the
M.Sc. degree in computer science and
technology with the School of Com-
puter Science and Engineering,
UESTC, in 2017, where he is
currently pursuing the Ph.D. degree
in computer science and technology.
His current research interests include
blockchain technology and privacy
and big data security.

KWAME OMONO ASAMOAH


received the B.Sc. degree in computer
XIAOJIANG DU (SM’09) received
MOHSEN GUIZANI (S’85–M’89–
the B.S. and M.S. degrees in electrical SM’99–F’09)
engineering from Tsinghua University, received the B.S. (Hons.) and M.S.
Beijing, China, in 1996 and 1998,
degrees in elec- trical engineering and
respectively, and the M.S. and Ph.D. the M.S. and Ph.D. degrees in
degrees in electrical engineering from
computer engineering from Syracuse
the University of Maryland at College Univer- sity, Syracuse, NY, USA, in
Park in 2002 and 2003, respectively.
1984, 1986, 1987, and 1990,
He is currently a tenured Professor respectively. He is currently a
with the Department of Computer and
Professor and the ECE Department
Information Sciences, Temple Chair at the University of Idaho. He
University, Philadelphia, PA, USA.
has served in various positions in
His research interests are wireless several academic institutions and
commu-
currently serves on the editorial boards
nications, wireless networks, security, and systems. He has of several international technical
over 200 journal and conference papers in these areas, as well
journals. He is the Founder and the Editor-in-Chief of
as a book published by Springer. He has been awarded over Wireless Communi- cations and Mobile Computing journal.
U.S. 5 million dollars in research grants. He is a Life
He has authored or coauthored over 400 publications in
Member of the ACM. refereed journals and conferences. He was the Chair of the
IEEE Communications Society, the Wireless Technical
Committee, and the TAOS Technical Committee.

También podría gustarte