CAT2
CAT2
ANDROID ARCHITECTURE:
Linux kernel
The foundation of the Android platform is the Linux kernel. For
example, the Android Runtime (ART) relies on the Linux kernel
for underlying functionalities such as threading and low-level
memory management.
Using a Linux kernel lets Android take advantage of key security
features and lets device manufacturers develop hardware
drivers for a well-known kernel.
Hardware abstraction layer (HAL)
The hardware abstraction layer (HAL) provides standard
interfaces that expose device hardware capabilities to the
higher-level Java API framework. The HAL consists of multiple
library modules, each of which implements an interface for a
specific type of hardware component, such as
the camera or Bluetooth module. When a framework API makes
a call to access device hardware, the Android system loads the
library module for that hardware component.
Android runtime
For devices running Android version 5.0 (API level 21) or higher,
each app runs in its own process and with its own instance of
the Android Runtime (ART). ART is written to run multiple
virtual machines on low-memory devices by executing Dalvik
Executable format (DEX) files, a bytecode format designed
specifically for Android that's optimized for a minimal memory
footprint. Build tools, such as d8, compile Java sources into DEX
bytecode, which can run on the Android platform.
Some of the major features of ART include the following:
• Ahead-of-time (AOT) and just-in-time (JIT) compilation
• Optimized garbage collection (GC)
• On Android 9 (API level 28) and higher, conversion of an app
package's DEX files to more compact machine code
• Better debugging support, including a dedicated sampling
profiler, detailed diagnostic exceptions and crash reporting, and
the ability to set watchpoints to monitor specific fields
Prior to Android version 5.0 (API level 21), Dalvik was the
Android runtime. If your app runs well on ART, then it can work
on Dalvik as well, but the reverse might not be true.
Android also includes a set of core runtime libraries that
provide most of the functionality of the Java programming
language, including some Java 8 language features, that the
Java API framework uses.
Native C/C++ libraries
Many core Android system components and services, such as
ART and HAL, are built from native code that requires native
libraries written in C and C++. The Android platform provides
Java framework APIs to expose the functionality of some of
these native libraries to apps. For example, you can
access OpenGL ES through the Android framework’s Java
OpenGL API to add support for drawing and manipulating 2D
and 3D graphics in your app.
If you are developing an app that requires C or C++ code, you
can use the Android NDK to access some of these native
platform libraries directly from your native code.
Java API framework
The entire feature-set of the Android OS is available to you
through APIs written in the Java language. These APIs form the
building blocks you need to create Android apps by simplifying
the reuse of core, modular system components and services,
which include the following:
• A rich and extensible view system you can use to build an app’s
UI, including lists, grids, text boxes, buttons, and even an
embeddable web browser
• A resource manager, providing access to non-code resources
such as localized strings, graphics, and layout files
• A notification manager that enables all apps to display custom
alerts in the status bar
• An activity manager that manages the lifecycle of apps and
provides a common navigation back stack
• Content providers that enable apps to access data from other
apps, such as the Contacts app, or to share their own data
Developers have full access to the same framework APIs that
Android system apps use.
System apps
Android comes with a set of core apps for email, SMS
messaging, calendars, internet browsing, contacts, and more.
Apps included with the platform have no special status among
the apps the user chooses to install. So, a third-party app can
become the user's default web browser, SMS messenger, or
even the default keyboard. Some exceptions apply, such as the
system's Settings app.
The system apps function both as apps for users and to provide
key capabilities that developers can access from their own app.
For example, if you want your app to deliver SMS messages,
you don't need to build that functionality yourself. You can
instead invoke whichever SMS app is already installed to deliver
a message to the recipient you specify.
https://www.geeksforgeeks.org/android-architecture/
2.Algorithms for implementing DSM:
CENTRAL SERVER ALGORITHM:
MIGRATION ALGORITHM:
READ REPLICATION ALGORITHM:
FULL REPLICATION ALGORITHM:
2. HADOOP DISTRIBUTED FILE SYSTEM -pdf
HDFS, a fundamental component of Hadoop, serves as a distributed file
system designed to scale seamlessly, tolerate faults, and ensure high
availability. The system’s structure revolves around master and slave nodes,
specifically the NameNode and DataNode.
i) NameNode and DataNode:
2 marks
Hardware support
Open Handset alliance
The Open Handset Alliance (OHA) is a consortium of technology and mobile companies
formed in November 2007. The alliance was established with the goal of developing open
standards for mobile devices, leading to the creation and subsequent release of Android, a
free, open-source mobile operating system
Load distributing algorithm
• Demand – driven –
Using sender initiated or receiver initiated polling techniques, a
node obtains the state of other nodes only when it desires to get
involved in either sending or receiving tasks. Because their
actions are dependent on the status of the system, demand-
driven policies are inherently adaptive and dynamic. The policy
here can be sender initiative : sender looks for receivers to
transfer the load, receiver initiated – receivers solicit load from
the senders and symmetrically initiated – a combination of both
sender & receiver initiated.
• Periodic –
At regular intervals, nodes exchange data. To inform localization
algorithms, each site will have a significant history of global
resource utilization over time. At large system loads, the
benefits of load distribution are negligible, and the periodic
exchange of information may thus be an unnecessary overhead.
• State – change – driven –
When a node’s state changes by a specific amount, it sends out
state information. This data could be forwarded to a centralized
load scheduling point or shared with peers. It does not collect
information about other nodes like demand-driven policy. This
policy does not alter its operations in response to changes in
system state. For example, if the system is already overloaded,
exchanging system state information on a regular basis will
exacerbate the problem.