20151117-2 选题

This commit is contained in:
DeadFire 2015-11-17 14:15:26 +08:00
parent 02b4b905e1
commit 8d39129619
2 changed files with 296 additions and 0 deletions

View File

@ -0,0 +1,125 @@
Install Android On BQ Aquaris Ubuntu Phone In Linux
================================================================================
![How to install Android on Ubuntu Phone](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/11/Install-Android-on-Ubuntu-Phone.jpg)
If you happen to own the first Ubuntu phone and want to **replace Ubuntu with Android on the bq Aquaris e4.5**, this post is going to help you.
There can be plenty of reasons why you might want to remove Ubuntu and use the mainstream Android OS. One of the foremost reason is that the OS itself is at an early stage and intend to target developers and enthusiasts. Whatever may be your reason, installing Android on bq Aquaris is a piece of cake, thanks to the tools provided by bq.
Lets see what to do we need to install Android on bq Aquaris.
### Prerequisite ###
- Working Internet connection to download Android factory image and install tools for flashing Android
- USB data cable
- A system running Linux
This tutorial is performed using Ubuntu 15.10. But the steps should be applicable to most other Linux distributions.
### Replace Ubuntu with Android in bq Aquaris e4.5 ###
#### Step 1: Download Android firmware ####
First step is to download the Android image for bq Aquaris e4.5. Good thing is that it is available from the bqs support website. You can download the firmware, around 650 MB in size, from the link below:
- [Download Android for bq Aquaris e4.5][1]
Yes, you would get OTA updates with it. At present the firmware version is 2.0.1 which is based on Android Lolipop. Over time, there could be a new firmware based on Marshmallow and then the above link could be outdated.
I suggest to check the [bq support page][2] and download the latest firmware from there.
Once downloaded, extract it. In the extracted directory, look for **MT6582_Android_scatter.txt** file. We shall be using it later.
#### Step 2: Download flash tool ####
bq has provided its own flash tool, Herramienta MTK Flash Tool, for easier installation of Android or Ubuntu on the device. You can download the tool from the link below:
- [Download MTK Flash Tool][3]
Since the flash tool might be upgraded in future, you can always get the latest version of flash tool from the [bq support page][4].
Once downloaded extract the downloaded file. You should see an executable file named **flash_tool** in it. We shall be using it later.
#### Step 3: Remove conflicting packages (optional) ####
If you are using recent version of Ubuntu or Ubuntu based Linux distributions, you may encounter “BROM ERROR : S_UNDEFINED_ERROR (1001)” later in this tutorial.
To avoid this error, youll have to uninstall conflicting package. Use the commands below:
sudo apt-get remove modemmanager
Restart udev service with the command below:
sudo service udev restart
Just to check for any possible side effects on kernel module cdc_acm, run the command below:
lsmod | grep cdc_acm
If the output of the above command is an empty list, youll have to reinstall this kernel module:
sudo modprobe cdc_acm
#### Step 4: Prepare to flash Android ####
Go to the downloaded and extracted flash tool directory (in step 2). Use command line for this purpose because youll have to use the root privileges here.
Presuming that you saved it in the Downloads directory, use the command below to go to this directory (in case you do not know how to navigate between directories in command line).
cd ~/Downloads/SP_Flash*
After that use the command below to run the flash tool as root:
sudo ./flash_tool
Youll see a window popped as the one below. Dont bother about Download Agent field, it will be automatically filled. Just focus on Scatter-loading field.
![Replace Ubuntu with Android](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/11/Install-Android-bq-aquaris-Ubuntu-1.jpeg)
Remember we talked about **MT6582_Android_scatter.txt** in step 1? This text file is in the extracted directory of the Andriod firmware you downloaded in step 1. Click on Scatter-loading (in the above picture) and point to MT6582_Android_scatter.txt file.
When you do that, youll see several green lines like the one below:
![Install-Android-bq-aquaris-Ubuntu-2](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/11/Install-Android-bq-aquaris-Ubuntu-2.jpeg)
#### Step 5: Flashing Android ####
We are almost ready. Switch off your phone and connect it to your computer via a USB cable.
Select Firmware Upgrade from the dropdown and after that click on the big download button.
![flash Android with Ubuntu](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/11/Install-Android-bq-aquaris-Ubuntu.jpeg)
If everything is correct, you should see a flash status in the bottom of the tool:
![Replace Ubuntu with Android](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/11/Install-Android-bq-aquaris-Ubuntu-3.jpeg)
When the procedure is successfully completed, youll see a notification like this:
![Successfully flashed Android on bq qauaris Ubuntu Phone](http://itsfoss.itsfoss.netdna-cdn.com/wp-content/uploads/2015/11/Install-Android-bq-aquaris-Ubuntu-4.jpeg)
Unplug your phone and power it on. You should see a white screen with AQUARIS written in the middle and at bottom, “powered by Android” would be displayed. It might take upto 10 minutes before you could configure and start using Android.
Note: If something goes wrong in the process, Press power, volume up, volume down button together and boot in to fast boot mode. Turn off again and connect the cable again. Repeat the process of firmware upgrade. It should work.
### Conclusion ###
Thanks to the tools provided, it becomes easier to **flash Android on bq Ubuntu Phone**. Of course, you can use the same steps to replace Android with Ubuntu. All you need is to download Ubuntu firmware instead of Android.
I hope this tutorial helped you to replace Ubuntu with Android on your bq phone. If you have questions or suggestions, feel free to ask in the comment section below.
--------------------------------------------------------------------------------
via: http://itsfoss.com/install-android-ubuntu-phone/
作者:[Abhishek][a]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:http://itsfoss.com/author/abhishek/
[1]:https://storage.googleapis.com/otas/2014/Smartphones/Aquaris_E4.5_L/2.0.1_20150623-1900_bq-FW.zip
[2]:http://www.bq.com/gb/support/aquaris-e4-5
[3]:https://storage.googleapis.com/otas/2014/Smartphones/Aquaris_E4.5/Ubuntu/Web%20version/Web%20version/SP_Flash_Tool_exe_linux_v5.1424.00.zip
[4]:http://www.bq.com/gb/support/aquaris-e4-5-ubuntu-edition

View File

@ -0,0 +1,171 @@
Linux 101: Get the most out of Systemd
================================================================================
Why do this?
- Understand the big changes in modern distros.
- See how Systemd replaces SysVinit.
- Get to grips with units and the new journal.
Hate mail, personal insults, death threats Lennart Poettering, the author of Systemd, is used to receiving these. The Red Hat employee recently ranted on Google+ about the nature of the FOSS community ([http://tinyurl.com/poorlennart][1]), lamenting that its “quite a sick place to be in”. In particular, he points to Linus Torvaldss highly acerbic mailing list posts, and accuses the kernel head honcho of setting the tone of online discussion, making personal attacks and derogatory comments the norm.
But why has Poettering received so much hate? Why does a man who simply develops open source software have to tolerate this amount of anger? Well, the answer lies in the importance of his software. Systemd is the first thing launched by the Linux kernel on most distributions now, and it serves many roles. It starts system services, handles logins, executes tasks at specified intervals, and much more. Its growing all the time, and becoming something of a “base system” for Linux providing all the plumbing tools needed to boot and maintain a distro.
Now, Systemd is controversial for various reasons: it eschews some established Unix conventions, such as plain text log files. Its seen as a “monolithic” project trying to take over everything else. And its a major change to the underpinnings of our OS. Yet almost every major distribution has adopted it (or is about to), so its here to stay. And there are benefits: faster booting, easier management of services that depend on one another, and powerful and secure logging facilities too.
So in this tutorial well explore Systemds features, and show you how to get the most out of them. Even if youre not a fan of the software right now, hopefully at least youll feel more comfortable with it by the end.
![Image](http://www.linuxvoice.com/wp-content/uploads/2015/10/eating-large.jpg)
**This tongue-in-cheek animation at [http://tinyurl.com/m2e7mv8][2] portrays Systemd as a rabid animal eating everything in its path. Most critics havent been so fluffy.**
### Booting and services ###
Almost every major distro has either adopted Systemd, or will do so in the next release (Debian and Ubuntu). In this tutorial were using a pre-release of Fedora 21 a distro that has been a great testing ground for Systemd but the commands and notes should be the same regardless of your distro. Thats one of the plus points of Systemd: it obviates many of the tiny, niggling differences between distros.
In a terminal, enter **ps ax | grep systemd** and look at the first line. The **1** means that its process ID 1, ie the first thing launched by the Linux kernel. So, once the kernel has done its work detecting hardware and organising memory, it launches the **/usr/lib/systemd/systemd** executable, which then launches other programs in turn. (In pre-Systemd days, the kernel would launch **/sbin/init**, which would then launch various other essential boot scripts, in a system known as SysVinit.)
Central to Systemd is the concept of units. These are configuration files with information about services (programs running in the background), devices, mount points, timers and other aspects of the operating system. One of Systemds goals is to ease and simplify the interaction between these, so if you have a certain program that needs to start when a certain mount point is created when a certain device gets plugged in, it should be considerably easier to make all this work. (In pre-Systemd days, hacking all this together with scripts could get very ugly.) To list all units on your Linux installation, enter:
systemctl list-unit-files
Now, **systemctl** is the main tool for interacting with Systemd, and it has many options. Here, in the unit list, youll notice that theres some formatting: enabled units are shown in green, and disabled are shown in red. Units marked as “static” cant be started directly theyre dependencies of other units. To narrow down the list to just services, use:
systemctl list-unit-files --type=service
Note that “enabled” doesnt necessarily mean that a service is running; just that it can be turned on. To get information about a specific service, for instance GDM (the Gnome Display Manager), enter:
systemctl status gdm.service
This provides lots of useful information: a human-readable description of the service, the location of the unit configuration file, when it was started, its PID, and the CGroups to which it belongs (these limit resource consumption for groups of processes).
If you look at the unit config file in **/usr/lib/systemd/system/gdm.service**, youll see various options, including the binary to be started (ExecStart), what it conflicts with (ie which units cant be active at the same time), and what needs to be started before this unit can be activated (the “After” line). Some units have additional dependency options, such as “Requires” (mandatory dependencies) and “Wants” (optional).
Another interesting option here is:
Alias=display-manager.service
When you activate **gdm.service**, you will also be able to view its status using **systemctl status display-manager.service**. This is useful when you know theres a display manager running, and you want to do something with it, but you dont care whether its GDM, KDM, XDM or any of the others.
![Image](http://www.linuxvoice.com/wp-content/uploads/2015/10/status-large.jpg)
**Use systemctl status, followed by a unit name, to see whats going on with a service.**
### Target locked ###
If you enter **ls** in the **/usr/lib/systemd/system** directory, youll also see various files that end in **.target**. A target is a way of grouping units together so that theyre started at the same time. For instance, in most Unix-like OSes theres a state of the system called “multi-user”, which means that the system has booted correctly, background services are running, and its ready for one or more users to log in and do their work at least, in text mode. (Other states include single-user, for doing administration work, or reboot, for when the machine is shutting down.)
If you look inside **multi-user.target**, you may be expecting to see a list of units that should be active in this state. But youll notice that the file is pretty bare instead, individual services make themselves dependencies of the target via the **WantedBy** option. So if you look inside **avahi-daemon.service**, **NetworkManager.service** and many other **.service** files, youll see this line in the Install section:
WantedBy=multi-user.target
So, switching to the multi-user target will enable those units that contain the above line. Other targets are available (such as **emergency.target** for an emergency shell, or **halt.target** for when the machine shuts down), and you can easily switch between them like so:
systemctl isolate emergency.target
In many ways, these are like SysVinit runlevels, with text-mode **multi-user.target** being runlevel 3, **graphical.target** being runlevel 5, **reboot.target** being runlevel 6, and so forth.
![Image](http://www.linuxvoice.com/wp-content/uploads/2015/10/unit-large.jpg)
**The unit configuration files might look foreign compared to traditional scripts, but theyre not hard to grasp.**
### Up and down ###
Now, you might be pondering: weve got this far, and yet we havent even looked at stopping and starting services yet! But theres a reason for this. Systemd can look like a complicated beast from the outside, so its good to have an overview of how it works before you start interacting with it. The actual commands for managing services are very simple:
systemctl stop cups.service
systemctl start cups.service
(If a unit has been disabled, you can first enable it with **systemctl enable** followed by the unit name. This places a symbolic link for the unit in the .wants directory of the current target, in the **/etc/systemd/system** folder.)
Two more useful commands are **systemctl restart** and **systemctl reload**, followed by unit names. The second asks the unit to reload its configuration file. Systemd is for the most part very well documented, so look at the manual page (**man systemctl**) for details on every command.
> ### Timer units: replacing Cron ###
>
> Beyond system initialisation and service management, Systemd has its fingers in various other pies too. Notably, it can perform the job of **cron**, arguably with more flexibility (and an easier to read syntax). **Cron** is the program that performs jobs at regular intervals such as cleaning up temporary files, refreshing caches and so forth.
>
> If you look inside the **/usr/lib/systemd/system** directory again, youll see that various **.timer** files are provided. Have a look at some of them with **less**, and youll note that they follow a similar structure to the **.service** and **.target** files. The difference, however, lies in the **[Timer]** section. Consider this example:
>
> [Timer]
> OnBootSec=1h
> OnUnitActiveSec=1w
>
> Here, the **OnBootSec** option tells Systemd to activate the unit 1 hour after the system has booted. Then the second option means: activate the unit once a week after that. Theres a huge amount of flexibility in the times that you can set enter **man systemd.time** for a full list.
>
> By default, Systemds accuracy for timing is one minute. In other words, it will activate the unit within a minute of the time you specify, but not necessarily to the exact second. This is done for power management reasons, but if you need a timer to be executed without any delay, right down to the microsecond, you can add this line:
>
> AccuracySec=1us
>
> Also, the **WakeSystem** option (which can be set to true or false) defines whether or not the timer should wake up the machine if its in suspend mode.
![Image](http://www.linuxvoice.com/wp-content/uploads/2015/10/systemd_gui-large.jpg)
**A Systemd GUI exists,although it hasnt been actively worked on for a couple of years.**
### Log files: say hello to journald ###
The second major component of Systemd is the journal. This is a logging system, similar to syslog, but with some major differences. And if youre a fan of the Unix way, prepare for your blood to boil: its a binary log, so you cant just parse it using your regular command line text tools. This design decision regularly whips up heated debates on the net, but it has some benefits too. For instance, logs can be more structured, with better metadata, so its easier to filter out information based on executable name, PID, time and so forth.
To view the journal in its entirety, enter:
journalctl
As with many other Systemd commands, this pipes the output into the **less** program, so you can scroll down by hitting space, use / (forward slash) to search, and other familiar keybindings. Youll also notice a sprinkling of colour here too, with warnings and failure messages in red.
Thats a lot of information; to narrow it down to the current boot, use:
journalctl -b
And heres where the Systemd journal starts to shine. Do you want to see all messages from the previous boot? Try **journalctl -b -1**. Or the one before that? Replace **-1** with **-2**. How about something very specific, like all messages from 24 October 2014, 16:38 onwards?”
journalctl -b --since=”2014-10-24 16:38”
Even if you deplore binary logs, thats still a useful feature, and for many admins its much easier than constructing a similar filter from regular expressions.
So weve narrowed down the log to specific times, but what about specific programs? For units, try this:
journalctl -u gdm.service
(Note: thats a good way to see the log generated by the X server.) Or how about a specific PID?
journalctl _PID=890
You can even request to just see messages from a certain executable:
journalctl /usr/bin/pulseaudio
If you want to narrow down to messages of a certain priority, use the **-p** option. With 0 this will only show emergency messages (ie its time to start praying to **$DEITY**), whereas 7 will show absolutely everything, including debugging messages. See the manual page (**man journalctl**) for more details on the priority levels.
Its worth noting that you can combine options as well, so to only show messages from the GDM service of priority level 3 (or lower) from the current boot, use:
journalctl -u gdm.service -p 3 -b
Finally, if you just want to have a terminal window open, constantly updating with the latest journal entries, as youd have with the tail command in pre-Systemd installations, just enter **journalctl -f**.
![Image](http://www.linuxvoice.com/wp-content/uploads/2015/10/journal-large.jpg)
**Binary logging isnt popular, but the journal has some benefits, like very easy filtering of information.**
> ### Life without Systemd? ###
>
> If you simply, absolutely cant get on with Systemd, you still have a few choices among the major distributions. Most notably, Slackware, the longest-running distro, hasnt made the switch yet but its lead developer hasnt ruled it out for the future. A few small-name distros are also holding out with SysVinit as well.
>
> But how long will this last? Gnome is becoming increasingly dependent on Systemd, and the other major desktop environments could follow suit. This is a cause of consternation in the BSD communities, as Systemd is heavily tied to Linux kernel features, so the desktops are becoming less portable, in a way. A half-way-house solution might arrive in the form of Uselessd ([http://uselessd.darknedgy.net][3]), which is a stripped-down version of Systemd that purely focuses on launching and supervising processes, without consuming the whole base system.
>
> ![Image](http://www.linuxvoice.com/wp-content/uploads/2015/10/gentoo-large.jpg)
>
> If you dont like Sysytemd, try Gentoo, which has it as a choice of init system, but doesnt force it on its users.
--------------------------------------------------------------------------------
via: http://www.linuxvoice.com/linux-101-get-the-most-out-of-systemd/
作者:[Mike Saunders][a]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:http://www.linuxvoice.com/author/mike/
[1]:http://tinyurl.com/poorlennart
[2]:http://tinyurl.com/m2e7mv8
[3]:http://uselessd.darknedgy.net/