INTRODUCTION TO DISTRIBUTED SYSTEMS
Why build a Distributed Systems?
There are a lot of advantages, including :
1. The ability to connect remote users with
remote resources in an open and scalable way.
2. Load Sharing
Chapter One: Introduction To Distributed Systems
Unit Contents
  – Introduction to distributed System
  – Definition of Distributed System
  – Goals of a Distributed System
  – Challenges of Distributed Systems
  – Types of DSs
             1.1. Introduction to Distributed System
Evolution of Distributed System
Computer systems are undergoing a revolution.
From 1945, when the modern computer era
began, until about 1985, computers were large
and expensive.
Starting in the mid-1980s, however, two
advances in technology began to change that
situation.
The first was the development of powerful
   microprocessors.
                      Conti…
• Initially, these were 8-bit machines, but soon 16-,
  32-, and even 64-bit CPUs became common.
The second development was the invention of
  high-speed computer networks.
• The local area networks or LANs allow dozens, or
  even hundreds, of machines within a building to
  be connected in such a way that small amounts
  of information can be transferred between
  machines in a millisecond.
                    Conti…
• Larger amounts of data can be moved
  between machines at rates of 10 to 100
  million bits/sec and sometimes more.
• The wide area networks or WANs allow
  millions of machines all over the earth to be
  connected at speeds varying from 64 Kbps
  (kilobits per second) to gigabits per second for
  some advanced experimental networks.
              1.2. Definition of Distributed System
• Distributed computing is a field of computer science
  that     studies distributed   systems.    Distributed
  computing also refers to the use of distributed
  systems to solve computational problems.
• A distributed system is a model in which components
  located on networked computers communicate and
  coordinate their actions by passing messages.
• The components interact with each other in order to
  achieve a common goal.
• It is a computer system consisting of several
  independent computers, connected by a network, that
  can work together to perform a task or provide a
  service.
                          Conti…
• It is a collection of independent computers that appear to
  its users as a single coherent system.
• Typical examples include:
• The World Wide Web,
• Networked file systems,
• DNS, and
• Massive Multiprocessor Supercomputers.
• face book
• It consists of multiple computers that do not share
  memory, storage or cpu.
• Because Each Computer has its own memory and runs its
  own operating system. The computers can communicate
  with each other through a communication network.
               1.3. Goals of a Distributed System
The following are very important goals that should
be met for an efficient distributed system.
• Heterogeneity.
• Openness.
• Security.
• Connecting Users and Resources
• Scalability.
• Failure Handling.
• Concurrency.
• Transparency.
                          Conti…
1.Heterogeneity: The Internet enables users to access services
and run applications over a heterogeneous collection of
computers and networks.
Variations and differences that must be handled:
  Network – The Internet-protocol is implemented over many
different networks
Hardware – difference in representation of data types on
different processors
Operating System – API to the same protocol and services
Varies Programming Languages – different representation of
character set and data structures implementation by different
developers.
 – ensure that different programs can communicate
   • requires agreement on a number of things (cf. standards)
                    Conti…
2. Openness: is an important goal of distributed
  system in which it offers services according to
  standard rules that describe the syntax and
  semantics of those services.
• Open distributed system must be flexible
  making it easy to configure and add new
  components without affecting existing
  components.
• Each component is continually open to
  interaction with other components.
                       Conti…
3. Security :Distributed systems should allow
  communication         between       programs/users/
  resources on different computers by enforcing
  necessary security arrangements.
• The security features are mainly intended to
  provide confidentiality, integrity and availability.
• Confidentiality (Secrecy & privacy) is protection
  against disclosure to unauthorised person.
• Integrity: provides protection against alteration
  and corruption.
• Availability keeps the resource accessible at any
  time and place.
                      Conti…
4. Scalability: At least three components:
Scalability is one of the most important goals which
are measured along three different dimensions.
• First, a system can be scalable with respect to its
   size which can add more user and resources to a
   system.- size scalability
• Second, users and resources can be geographically
   apart- (geographical scalability).
• Third, it is possible to manage even if many
   administrative organizations are spanned.-Number
   of administrative domains (administrative
   scalability)
                      Conti…
5. Connecting Remote Users with Remote Resources
• The main goal of a distributed system is to make
   it easy for users to access remote resources and
   to share them with others in a controlled way.
• It is cheaper to let a printer be shared by several
   users than buying and maintaining printers for
   each user.
• Collaborating and exchanging information can be
   made easier by connecting users and resource.
                    Conti…
6. Transparency:
• A distributed system needs to hide the
  location of its processes and resources even
  though physically distributed across multiple
  computers.
• The various transparencies need to be
  considered are access, location, migration,
  relocation, replication, concurrency, failure
  and persistence.
• Aiming for distributed transparency should be
  considered along with performance issues.
                             Conti…
Transparency   Description
Access         Hide differences in data representation and how a resource is
               accessed
Location       Hide where a resource is located
Migration      Hide that a resource may move to another location
Relocation     Hide that a resource may be moved to another location while
               in use
Replication    Hide that a resource is replicated(Copying) ata different places.
Concurrency    Hide that a resource may be shared by several competitive
               users.
Failure        Hide the failure and recovery of a resource
                            Conti…
8. Failure Handling
•This means that components that are prone to defects are
replicated in such a way that if a component fails, one or more
of the non-failed replicas will continue to provide service with
no appreciable disruption.
•Failure may be:
Hardware, software and network fail!!
DS must maintain availability even in cases where
hardware/software/network have low reliability.
 Many Techniques for handling failures
 Detecting failures (checksum)
Tolerating failures
Recovery from failures
 Redundancy (replicate servers in failure-independent ways)
                       Conti…
9. Concurrency: Users and Applications should be
  able to access shared data or objects without
  interference between each other. =>
  Concurrency Control
• Shared Resources should be Synchronized.
• A database is a set of data which deals with
  organizational activities.
• DDB is a scheme that allows decentralization for the
  management of data through same or common
  language. Concurrency control deals with the issues in
  coordinating concurrent accesses to a database in a
  multi-user fashion.
                     Conti…
• Locking is a method used to control concurrent
  access to data. A lock is a variable having data
  items associated with it. It is a status of the
  item and it tells about all operations that are
  possibly applicable on it. For each item in
  database one lock is available.
• Locks are used as a means of synchronizing the
  access by concurrent transactions to the
  database item. The most common algorithms
  that offer concurrency manipulation or controls
  are two phase locking(2PL), Times-tamping.
                    Conti…
• 2pl: Shared and Exclusive locks
• Write-lock (exclusive lock) is associated with a
  database object by a transaction (Terminology:
  "the transaction locks the object," or "acquires
  lock                    for                  it")
  before writing (inserting/modifying/deleting)
  this object.
•Read-lock (shared lock) is associated with a
database       object     by     a     transaction
before reading (retrieving the state of) this
object.
                         Conti…
•Serializability:     Ideally,   transactions        should
be serializable.
• Transactions are said to be serializable if the results of
running transactions simultaneously are the same as
the results of running them serially— that is, one after
the other. It is the classical concurrency scheme. It
ensures that a schedule for executing concurrent
transactions is equivalent to one that executes the
transactions serially in some order.
•A transaction in a database system must maintain
Atomicity, Consistency, Isolation, and Durability −
commonly known as ACID properties − in order to
ensure accuracy of a transaction.
     1.4. Challenges of Distributed Systems
The major challenges in distributed systems are
listed below:
• Heterogeneity:
• Transparency:
• Openness.
• Concurrency.
• Security.
• Scalability.
• Partial Failure
• Privacy
                     1.5. Types of DS
1)Distributed processing: is a technique for implementing a
single logical set of processing functions across a number of
physical devices, so that each performs some part of the total
processing required.
2)A distributed application is software that is executed or run
on multiple computers within a network.
•These applications interact in order to achieve a specific goal
or task. Traditional applications relied on a single system to
run them.
1)A distributed file system (DFS): is a file system with data
stored on a server. The data is accessed and processed as if it
was stored on the local client machine. The DFS makes it
convenient to share information and files among users on a
network in a controlled and authorized way.
               1.5. Types of DS
•A distributed operating system: is a software
over a collection of independent, networked,
communicating,     and      physically    separate
computational nodes. Each individual node holds
a specific software subset of the global
aggregate operating system. Each subset is a
composite of two distinct service provisioners.
1)Distributed Computing Systems: Used for high
performance computing tasks
•Cluster computing systems
•Grid computing systems
                            Conti…
1)Distributed Information Systems: Systems mainly used for
management and integration of business functions.
• Transaction processing systems
• Enterprise Application Integration
1)Distributed Pervasive Systems or Ubiquitous computing: is a
concept in software engineering and computer science
where computing is made to appear anytime and everywhere.
•Mobile and embedded systems
•Automated Home systems
•Sensor networks
1)Cloud Computing is an information Technology(IT) paradigm that
enables ubiquitous access to shared pools of configurable system
resources and       higher-level     services that    can      be
rapidly provisioned with minimal management effort, often over
the Internet.
•Loosely coupled systems
                    Conti…
Grid Computing Systems: grids are usually
consists of multiple computers sharing
information over the Internet, they are
composed of different types of computers
(hardware, OS, network, security, etc.) −loosely
coupled.
                     Conti…
1)Tightly coupled (clustered computers) —
refers typically to a set of highly integrated
machines that run the same process in parallel,
subdividing the task in parts that are made
individually by each one, and then put back
together to make the final result. Unlike grid
computers,       computer       clusters   have
each node set to perform the same task,
controlled and scheduled by software. The
components of a cluster are usually connected
to each other through fast local area networks.
                     Conti…
• In most circumstances, all of the nodes use the
same hardware and the same operating system.
•Clusters are usually deployed to improve
performance and availability over that of a
single computer, while typically being much
more cost-effective than single computers of
comparable speed or availability.
                    Conti…
• Cluster differs from Cloud and Grid in that
  a cluster is a group of computers connected
  by a local area network (LAN), whereas cloud
  and grid are more wide scale and can be
  geographically distributed.
              Multiprocessor Systems
• A multiprocessor system is simply a computer that has more than
  one CPU on its motherboard or inside its own die. If the operating
  system is built to take advantage of this, it can run different
  processes on different CPUs, or different threads belonging to the
  same process.
• Over the years, many different multiprocessing options have been
  explored for use in distributed computing. CPUs can be connected
  by bus or switch networks, use shared memory or their own private
  RAM, or even a hybrid approach.
• These days, multiprocessor systems are available commercially for
  end-users, and mainstream operating systems like Mac OS X,
  Microsoft Windows and Linux already have built-in support for this.
  Additionally, recent Intel CPUs have begun to employ a technology
  called Hyper-threading that allows more than one thread (usually
  two) to run on the same CPU. New Intel processors also feature
  multiple processor cores to double the number of threads again.
                 Multicomputer Systems
• A multicomputer system is a system made up of several
  independent computers interconnected by a telecommunications
  network.
• Multicomputer systems can be homogeneous or heterogeneous:
  A homogeneous distributed system is one where all CPUs are
  similar and are connected by a single type of network. They are
  often used for parallel computing which is a kind of distributed
  computing where every computer is working on different parts of
  a single problem.
• In contrast a heterogeneous distributed system is one that can be
  made up of all sorts of different computers, eventually with vastly
  differing memory sizes, processing power and even basic
  underlying architecture. They are in widespread use today, with
  many companies adopting this architecture due to the speed with
  which hardware goes obsolete and the cost of upgrading a whole
  system simultaneously.
              Multicomputer Systems
• 3-tier architecture — Application servers usually store
  data on a third machine, known as the database
  server. This is called three-tier architecture whereas
  generic client/server architecture is two-tier. Three
  tier systems move the client intelligence to a middle
  tier so that stateless clients can be used. This
  simplifies application deployment. Most web
  applications are 3-Tier.
• N-tier (Multi-Tier) architecture — N-Tier refers
  typically to web applications which further forward
  their requests to other enterprise services. This type
  of application is the one most responsible for the
  success of application servers.
    1.6. Components or elements of DS
• A distributed system consists of hardware and
  software components located in a network of
  computers that communicate and coordinate
  their actions only by passing messages.
• Hardware
• Software
• Users
• Data or Resources to be shared /accessed
• Network or communication link
•For synchronous data transfer, both the sender and
receiver access the data according to the same
clock.
•Synchronous(Full Duplex) Transmission is clock
pulse driven where as, Asynchronous Transmission
is event driven.
•Synchronous Transmission is efficient, reliable and
is used for transferring a large amount of data. It
provides real-time communication between
connected      devices.     Chat   Rooms,      Video
Conferencing, telephonic conversations, as well as
face to face interactions, are some of the examples
of Synchronous Transmission.
• In Asynchronous Transmission data flows in a
  half duplex mode, 1 byte or a character at a
  time. It transmits the data in a continuous
  stream of bytes. In general, the size of a
  character sent is 8 bits to which a parity bit is
  added i.e. a start and a stop bit that gives the
  total of 10 bits. It does not require a clock for
  synchronization; rather it uses the parity bits to
  tell the receiver how to interpret the data.
• It is simple, fast, economical and does not
  require a 2-way communication. Letters,
  emails, forums, televisions and radios are some
  of the examples of Asynchronous Transmission.
• Key Differences Between Serial And Parallel Transmission
• Serial transmission requires a single line to communicate and
  transfer data whereas, parallel transmission requires multiple lines.
• Serial transmission used for long distance communication whereas,
  the parallel transmission used for shorter distance.
• Error and noise are least in serial as compared to parallel
  transmission. Since one bit follows another in Serial Transmission
  whereas, in Parallel Transmission multiple bits are sent together.
• Parallel transmission is faster as the data is transmitted using
  multiples lines whereas, in Serial transmission data flows through a
  single wire.
• Serial Transmission is full duplex as the sender can send as well as
  receive the data whereas, Parallel Transmission is half duplex since
  the data is either sent or received.
• Serial transmission cables are thinner, longer and economical in
  comparison with the Parallel Transmission cables.
• Serial Transmission is reliable and straightforward whereas, Parallel
  Transmission is unreliable and complicated.
 Chapter Two: Distributed Systems Architecture
Outlines
 Architectural Styles: Important styles of architecture for
  distributed systems.
      Layered architectures
      Object-based architectures
      Data centered architectures
      Event-based architectures
 System Architectures:
       Centralized architectures
              Application layering
              Multitier architectures
       Decentralized architectures
              Structured peer-to-peer
              Unstructured peer-to-peer
       Hybrid architectures
              Edge-server systems
              Collaborative distributed systems
    Distributed Systems Organization
 It is now commonly accepted that designing
  or adopting an architecture is crucial for the
  successful development of large systems.
 The notion of an architectural style is
  important. Such a style is formulated in
  terms of components, the way that
  components are connected(connectors) to
  each other, the data exchanged between
  components, and finally how these
  elements are jointly configured into a
  system.
 A component is a modular unit with well-
  defined required and provided interfaces
  that is replaceable within its environment.
 Software architectures: how various
  software components are organized and
  how they interact.
 System architecture: An instance of a
  software architecture after deciding on the
  software components, their interaction and
  their placement.
For example, a connector can be formed by the
facilities for (remote) procedure calls, message
passing, or streaming data.
Using components and connectors, we can
come to various configurations, which, in turn
have been classified into architectural styles.
Several styles have by now been identified, of
which the most important ones for distributed
systems are:
1. Architectural Styles
• Formulated in terms of components, and the
way they are connected by connectors:
•A component is a modular unit with well-
defined interfaces; replaceable; reusable
•A connector is a communication link between
modules; mediates coordination or cooperation
among components.
• Four styles that are most important:
• Layered architecture
• Object-based architecture
• Data-centered architecture
• Event-based architecture
1.Layered architectures:
•The basic idea for the layered style is simple:
•Components are organized in a layered fashion
where a component at layer L; is allowed to call
components at the underlying layer Li.
•A key observation is that control generally flows
from layer to layer: requests go down the
hierarchy whereas the results flow upward.
2. Object-based architectures
•In this case components are objects, and these components
are connected through a (remote) procedure call mechanism.
•The layered and object-based architectures still form the most
important styles for large software systems.
•Object-based style for distributed object systems.
• It is less structured
component = object
connector = RPC or RMI or CORBA
3. Data-Centered (shared data space) architectures:
Data-centered architectures evolve around the idea
that processes communicate through a common
(passive or active) repository.
For example, a wealth of networked applications
have been developed that rely on a shared distributed
file system in which virtually all communication takes
place through files.
Likewise, Web-based distributed systems, are largely
data-centric: processes communicate through the use
of shared Web-based data services.
4. Event-Based Architectures:
In     event-based     architectures,    processes     essentially
communicate through the propagation of events.
For distributed systems, event propagation has generally been
associated with what are known as publish/subscribe systems.
The basic idea is that processes publish events after which the
middleware ensures that only those processes that subscribed to
those events will receive them. The main advantage of event-
based systems is that processes are loosely coupled.
In principle, they need not explicitly refer to each other. This is
also referred to as being decoupled in space.
•Publish-subscribe:           publish–subscribe is
a messaging pattern where senders of messages,
called publishers, do not program the messages to
be sent directly to specific receivers, called
subscribers, but instead categorize published
messages into classes without knowledge of
which subscribers, if any, there may be. Similarly,
subscribers express interest in one or more classes
and only receive messages that are of interest,
without knowledge of which publishers, if any,
there are.
2. System Architectures
 Distributed systems are actually organized by
 considering where software components are
 placed.
  Centralized architectures
    Application layering & Multitier architectures
 Decentralized architectures
    Structured peer-to-peer
    Unstructured peer-to-peer
 Hybrid architectures
    Edge-server systems
    Collaborative distributed systems
A. Centralized Architectures
A centralized architecture consists of a server and multiple
clients.
In the basic client-server(request-reply) model, processes in a
distributed system are divided into two (possibly overlapping)
groups.
 A server is a process or program that can receive a request,
   process it and can send a response.
 For example a server implementing a specific service such as a
   file system service or a database service.
 A client is a process that requests a service from a server by
   sending it a request and subsequently waiting for a reply.
 Communication between server/clients:
    Connectionless protocol: UDP is an example. allows for packets of data
     to be transmitted between applications.
    Connection-oriented protocol: TCP is the most common and Reliable .
A. Centralized Architectures
General interaction between a client and a server.
•Communication between a client and a server can
be implemented by means of a simple
connectionless protocol when the underlying
network is fairly reliable as in many local-area
networks.
• In these cases, when a client requests a service, it
simply packages a message for the server,
identifying the service it wants, along with the
necessary input data. The message is then sent to the
server. The latter, in turn, will always wait for an
incoming request, subsequently process it, and
package the results in a reply message that is then
sent to the client. Using a connectionless protocol
has the obvious advantage of being more efficient.
•As long as messages do not get lost or corrupted, the
request/reply protocol just sketched works fine.
•Unfortunately, making the protocol resistant to occasional
transmission failures is not trivial.
•The only thing we can do is possibly let the client resend
the request when no reply message comes in.
•The problem, however, is that the client cannot detect
whether the original request message was lost, or that
transmission of the reply failed.
•If the reply was lost, then resending a request
may result in performing the operation twice.
•As an alternative, many client-server systems use a
reliable connection-oriented protocol. Although this solution
is not entirely appropriate in a local-area network due to
relatively low performance, it works perfectly in wide-area
systems in which communication is inherently unreliable.
• For example, virtually all Internet application protocols are
based on reliable TCP/IP connections.
•In this case, whenever a client requests a service, it first
sets up a connection to the server before sending the
request.
•The server generally uses that same connection
to send the reply message, after which the connection is torn
down. The trouble is that setting up and tearing down a
connection is relatively costly, especially when
the request and reply messages are small.
     1. Application Layering
•The client-server model has been subject to many
debates and controversies over the years.
• One of the main issues was how to draw a clear
distinction between a client and a server.
•Not surprisingly, there is often no clear distinction. For
example, a server for a distributed database may
continuously act as a client because it is forwarding
requests to different file servers responsible for
implementing the database tables. In such a case, the
database server itself essentially does no more than
process queries.
•However, considering that many client-server
applications are targeted toward supporting user access
to databases, many people have advocated a distinction
between the following three levels, essentially
following the layered architectural style we discussed
previously:
• Layers of architectural style:
 The user-interface level: Client
 The processing level: Client or Server :The     processing level typically
  contains the applications.
 The data level: Server. The data level manages the actual data
  that is being acted on. This level is persistent, which implies data
  is stored outside of an application. Typically a file system or
  database but could also be a NoSQL store (like Hadoop) or an
  object store.
The simplified organization of an Internet search engine into three
different layers (3-tier architecture).
•The simplest organization is to have only two types of machines:
1. A client machine containing only the programs implementing
(part of) the user-interface level.
• 2. A server machine containing the rest, that is the programs
implementing the processing and data level.
• In this organization everything is handled by the server while the
client is essentially no more than a dumb terminal, possibly with a
pretty graphical interface.
•There are many other possibilities, of which we explore some of
the more common ones in this section.
•One approach for organizing the clients and servers is to
distribute the programs in the application layers of the previous
section across different machines.
• As a first step, we make a distinction between only two kinds of
machines: client machines and server machines, leading to what is
also referred to as a (physically two-tier architecture).
•   E.g.
•   A
•   B
•   C: The front end can then check the correctness and consistency of
    the form, and where necessary interact with the user & Word
    processor
•   D: For example, many banking applications run on an end-user's
    machine where the user prepares transactions and such. Once
    finished, the application contacts the data- base on the bank's
    server and uploads the transactions for further processing.
•   E: represents the situation where the client's local disk contains
    part of the data. For example, when browsing the Web, a client
    can gradually build a huge cache on local disk of most recent
    inspected Web pages.
•   D & E are more popular and preferable systems.
•   A-c thin clients
•   D & E fat clients
  2. Multitier Architectures
The simplest organization is to have only two types of
machines:
A client machine containing only the programs
implementing (part of) the user-interface level
A server machine containing the rest,
   the programs implementing the processing and data level
Clients can be fat or thin clients. Servers can act as
clients as well, leading to a three-tier design.
An example of a server acting as client(3-tie
architecture).
2. Decentralized Architecture
 Multitier client-server architectures are a direct consequence of
dividing applications into a user-interface, processing components,
and a data level. The different tiers correspond directly with the
logical organization of applications.
 In many business environments, distributed processing is
equivalent to organizing a client-server application as a multitier
architecture.
We refer to this type of distribution as vertical distribution. The
characteristic feature of vertical distribution is that it is achieved
by placing logically different components on different machines.
The term is related to the concept of vertical fragmentation as
used in distributed relational databases, where it means that tables
are split column-wise, and subsequently distributed across
multiple                                                     machines.
 Again, from a system management perspective, having a vertical
distribution can help: Functions are logically and physically split
across multiple machines, where each machine is tailored or
assigned to a specific group of functions.
However, vertical distribution is only one way of organizing client-
server applications. In modem architectures, it is often the
distribution of the clients and the servers that counts, which we
refer to as horizontal distribution.
In this type of distribution, a client or server may be physically split
up into logically equivalent parts, but each part is operating on its
own share of the complete data set, thus balancing the load.
In this section we will take a look at a class of modern system
architectures that support horizontal distribution, known as peer-
to-peer systems.
1. Peer2peer: An architecture where there is no special
machine or machines that provide a service or manage
the network resources. Instead all responsibilities are
uniformly divided among all machines, known as peers.
Each node or instance of the program is both a "client"
and a "server" and each has equivalent responsibilities.
             Hybrid Architecture
Two types:
                              Types of servers
•   Server systems can be broadly categorized into two kinds:
     – transaction servers which are widely used in relational database systems, and
     – data servers, used in object-oriented database systems
• Also called query server systems or SQL server systems
     – Clients send requests to the server
     – Transactions are executed at the server
     – Results are shipped back to the client.
Stateless vs. stateful server:
          DSs Projects(part I) (2 weeks) 20%
1. file upload and download from local database server
2. file upload and download from lan computer
3. file attach/send to e-mail
4.data encryption and decryption
5. password reset through e-mail
         PHP,JAVA,C#
Presentation Style or Content:
1.Aim
2. Description
3.Development Tools
3. Implementation strategies
4. Algorithms Used
5. Implementations
          5-10 slides.
                         Peace Presentation(5%)
1)    Structured peer-peer
2)    Unstructured peer-peer
3)    Super-peer
4)    Hybrid architecture
      Edge-server systems
      Collaborative distributed systems
5)    Self -Management In Distributed Systems
6)    Architectures Versus Middleware
            Chapter 3: Processes
Outline:
3.1. Introduction to Threads
3.2. Threads in Distributed Systems
3.3. Multithreading
3.3. Clients
3.4. Servers
3.5. Code Migration
          Chapter 4:Communication
Unit Contents:
1. Layer Protocols
2. Types of Communication
3. RMI, RPC & COBRA
              Chapter-5:Naming
Outline:
1. Names, Identifies, and Addresses
2. Flat Naming
3. Structured Naming
4. Attribute Based Naming