Recent Posts


Simple, Elastic & Agile

By Dale Reagan | November 19, 2013

Ok, something from 50+ years ago I encountered during my AM reading –  I stumbled across this item that relates well to keeping stuff ‘simple’ (i.e. short in duration…)

The context was actually a ‘biz’ article with something like, “For meetings, most results/work occur during the ~1st 20 minutes of the meeting – the ‘rest’ of the meeting tends to be non-productive…”

My take – It suggests that during meetings, each topic/item/problem may best be resolved if/when you can limit discussing them to short durations –  agile!]

Work is “elastic” – it stretches to fill the time allotted…

Which led to:’s_law

Quote from Wikipedia:

First articulated by Cyril Northcote Parkinson as part of the first sentence of a humorous essay published in The Economist in 1955,[1][2] it was later reprinted together with other essays in the book Parkinson’s Law: The Pursuit of Progress (London, John Murray, 1958). He derived the dictum from his extensive experience in the British Civil Service.

The current form of the law is not that which Parkinson refers to by that name in the article. Rather, he assigns to the term a mathematical equation describing the rate at which bureaucracies expand over time. Much of the essay is dedicated to a summary of purportedly scientific observations supporting his law, such as the increase in the number of employees at the Colonial Office while Great Britain’s overseas empire declined (indeed, he shows that the Colonial Office had its greatest number of staff at the point when it was folded into the Foreign Office because of a lack of colonies to administer). He explains this growth by two forces: (1) “An official wants to multiply subordinates, not rivals” and (2) “Officials make work for each other.” He notes in particular that the total of those employed inside a bureaucracy rose by 5–7% per year “irrespective of any variation in the amount of work (if any) to be done”.

In 1986, Alessandro Natta complained about the swelling bureaucracy in Italy. Mikhail Gorbachev responded that “Parkinson’s Law works everywhere”.[3]

Corollaries In time, however, the first-referenced meaning of the phrase has dominated, and sprouted several corollaries, the most well known being the Stock-Sanford Corollary to Parkinson’s Law:

If you wait until the last minute, it only takes a minute to do.[4]

Other corollaries include (relating to computers):

Data expands to fill the space available for storage. or Storage requirements will increase to meet storage capacity.

Generalization “Parkinson’s Law” could be generalized further still as:

The demand upon a resource tends to expand to match the supply of the resource.

An extension is often added to this, stating that:

The reverse is not true.

This generalization has become very similar to the economic law of demand; that the lower the price of a service or commodity, the greater the quantity demanded.

Some define Parkinson’s Law in regard to time as:

The amount of time which one has to perform a task is the amount of time it will take to complete the task.



Topics: Problem Solving | Comments Off on Simple, Elastic & Agile

Android: Working with Data structures using Python (part 1)

By Dale Reagan | August 18, 2013


Ok, you have an Android device (or two) and you want to explore the available data structures using Python and SL4A.  Where to start?

For this post we will assume that:

In my case, my background includes mostly programming in C (and some embedded systems work) as well as what I will loosely call ‘shell programming’.  If you explore the Android development eco-system you will find that it supports primarily Java (the main language used for Android development [via the Android SDK]) but there is also support for C programming via the Android NDK.  The SDK also includes a number of ‘shell’ tools which provide the ‘glue’ needed to communicate with Android devices via USB connections.

Enter SL4a – this solution provides a scripting interface into the Android environment via multiple scripting languages.  Once you establish your desired languages under SL4a then you have a simple/quick means to try/explore/proto-type your ideas.

SL4a provides a consistent data interface to the underlying Android (Java) data structures across it’s supported scripting languages so once understood, you could port to any desired scripting solution.  In this case I chose to work with Python since I wanted to learn a bit more about the language.  It just so happens that there is a very good book (~2011) by Paul Ferrill, Pro Android Python with SL4A, which you can purchase in print or E-book form.  With a  bit of searching, you can also locate a number of simple/working Android specific Python examples (beyond the examples found on the SL4A Wiki pages.)

After reviewing the example/sample SL4A scripts, I started my exploring how to view the data being returned via the SL4A API.  This led me to a number of Python sites as I tried to understand the data being returned.   My specific interest was to have a means to consistently display the returned data.  The structure of the data returned via function calls is consistent and contains three (3) entities:

  1. some sort of ID – appears to be somewhat random
  2. data returned by the desired query (i.e. GPS data) and
  3. an error code/status.

NOTE – before going any further you probably need to download, install, explore SL4A – otherwise, the rest of this post may not make much sense or provide any benefit.

The structure of the second item, however, will vary based on the what is being accessed.  This is where I had to dig a bit to get output that I could manipulate.  This data could be:

The introductory pages for SL4a provide this bit of info:

All SL4A API calls return an object with three fields:

  1. id: a strictly increasing, numeric id associated with the API call.
  2. result: the return value of the API call, or null if there is no return value.
  3. error: a description of any error that occurred or null if no error occurred.

I was thinking that it might be useful/interesting to explore the ‘types’ of data being returned.  Once I know that type of data then I can present it (format the output) in a consistent, easy-to-use manner – or so I thought.  Turns out this notion is a non-Phythonic approach (based on some reading, it seems that in Python the *preferred* approach is to ‘try stuff’ and then ‘ask forgiveness’ instead of figuring out what you have and then doing ‘something’.)  This is not how *I think* (at least not yet) so I venture forth using an approach that I am familiar with – so, you are advised that my Python code may be un-Pythonic – but it should still work.  I will guess that if you know *enough* about Python then deciding on how to best deal with unknown data structures would allow you to create a Pythonic solution…

JSON and Android devices

Mr. Ferrill discusses a number of relevant background topics including JavaScript Object Notation (JSON) – “a way of defining a data structure or an object in much the same way you would in the context of a program.”  He notes that *many* (ok, not all) of the API calls return information using JSON to provide structure to the data.  The Python language includes significant support for JSON data structures so there are a number of resources available (i.e. modules/documentation/examples) outside of the Android environment that can be used as resources.

Mr. Ferrill continues,  When you move a JSON object form one place to another, you must serialize and the deserialze that object.  This requires the json.load() and json.loads() functions for  decoding, and json.dump() plus json.dumps() for encoding.”  Ok, until I encountered this bit of information (which is a bit more detailed than the three items list above) I was struggling with ‘moving’ the data returned by API calls.  Refactoring the presentation a bit:

FYI – I am placing the code from this post on GitHub.

I started out doing using a function that was something like this:

 def what_print(text_msg, this_struct):
     my_type = type(this_struct).__name__
     if my_type == 'Result':
         print 'Result: ', this_struct
         if my_type == 'dict':
             print 'Dictionary: ', this_struct
             if my_type == 'list':
                 print 'List: ', this_struct
                 print 'Curious: %s', text_msg, this_struct

Using a *case* statement would make the above simpler, but, Python does not seem to use this approach (again, not a Pythonista…)  So, now we have a simple function to explore *results* with, as in:

  1. use API to fetch data
  2. pass the data to the preceding function
  3. review the output

Here is a simple example to read sensor data from an Android device using Python via SL4A.

import android, time
droid = android.Android()
droid.startSensingTimed(1, 250)

## get ALL data returned by the API call
raw_data = droid.readSensors()
print "Raw Data Returned by API: ', raw_data

## now just fetch the 'results'
raw_result = droid.readSensors().result
print "Raw RESULT Data Returned by API: ', raw_result

## after adding the 'what_print' function to the code let's see what the 'data types' are
what_print('Raw Data', raw_data)
what_print('Raw Result', raw_result

Note that there are ‘other’ ways to get to the ‘parts’ of the data, i.e. using ‘indexing’:

raw_result[1] ## remember, there are three (3) parts, accessed via: 0, 1, 2
raw_result_err[2] ## just the error code/status
raw_result_id[0] ## just the ID for this data


So, putting the above together (and reminding you that Python is very picky about ‘spaces’ so you may see interesting results or the code may not work or only work partially if you copy/paste – best to fetch from Github – also noting that the Github source has more output refinements – added new lines and tabs…)

######### sample output
 ### What type of data do we have? ###
        Raw Data Returned by API:
        Result(id=2, result={u'light': 89, u'accuracy': 3, u'pitch': -0.17525501549243927, u'xMag': -35.628616000000001, u'azimuth': 0.85555952787399292, u'zforce': 9.8293949999999999, u'yfo
rce': 1.7405846, u'time': 1376845710.2449999, u'yMag': 28.437930999999999, u'zMag': -15.815201999999999, u'roll': -0.0094534987583756447, u'xforce': 0.092924950000000006}, error=None)

[note the three components above: Id, result, and error status..]

        Raw RESULT Data Returned by API:
        {u'light': 89, u'accuracy': 3, u'pitch': -0.17525501549243927, u'xMag': -35.628616000000001, u'azimuth': 0.85555952787399292, u'zforce': 9.8293949999999999, u'yforce': 1.7405846, u't
ime': 1376845710.2449999, u'yMag': 28.437930999999999, u'zMag': -15.815201999999999, u'roll': -0.0094534987583756447, u'xforce': 0.092924950000000006}

        What-Print | Raw Data is type: Result:
        Result(id=2, result={u'light': 89, u'accuracy': 3, u'pitch': -0.17525501549243927, u'xMag': -35.628616000000001, u'azimuth': 0.85555952787399292, u'zforce': 9.8293949999999999, u'yfo
rce': 1.7405846, u'time': 1376845710.2449999, u'yMag': 28.437930999999999, u'zMag': -15.815201999999999, u'roll': -0.0094534987583756447, u'xforce': 0.092924950000000006}, error=None)

        What-Print | Raw Result is type: Dictionary:
        {u'light': 89, u'accuracy': 3, u'pitch': -0.17525501549243927, u'xMag': -35.628616000000001, u'azimuth': 0.85555952787399292, u'zforce': 9.8293949999999999, u'yforce': 1.7405846, u't
ime': 1376845710.2449999, u'yMag': 28.437930999999999, u'zMag': -15.815201999999999, u'roll': -0.0094534987583756447, u'xforce': 0.092924950000000006}

Final note – tested with Android 4.3 using running Python 2.6 via SL4A

Next time I will connect this output to using JSON – as always, your mileage will vary. 🙂


Topics: Computer Technology, Hardware, Problem Solving, Sensors | Comments Off on Android: Working with Data structures using Python (part 1)

Google errors: url(data:image/png;base64…???

By Dale Reagan | May 3, 2013

Some curious 404 errors started showing up in ~2011 – based on some digging there is an attribution to Google tools?

In your log files you see something like:

“GET /url(…..5CYII%3d) HTTP/1.1”   OR

“GET /some_URL_path/url(…..5CYII%3d) HTTP/1.1”

The above type of encoding is described on as the data URI scheme – the objective for using such encoding is to improve web server response time by reducing the number of unique server calls to fetch small (image) files; just encode them in your HTML; the idea is similar to placing all Javascript in one file.  In some cases, using this approach may increase the total number of bytes being transferred since some forms of data (i.e. images) will be much require more bytes in any text-encoded format.

According the WikiPedia link (above), data URIs are supported only for the following elements and/or attributes:

As with any solution, there are trade-offs – there are a number of security concerns with this approach – I am not convinced that benefits out-weigh concerns…  A number of encoding examples are provided on the Wikipedia link including examples for:  images, CSS, Javascript, HTML, PHP. One of the warning signs for Open Source software are if it requires the inclusion of hidden/encoded code using this approach – if you use such code you could be compromising your server(s) or your site visitors – this is a noted problem with FREE themes and plugins for various Open Source projects.

<!----- encoded data between comment markers ------->
<div id="data-uri-test-2"></div>
<style type="text/css">
#data-uri-test-2 {
 width: 180px;
 height: 180px;
 background-image: url(%2buAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A%2fwD%2foL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9oGAhENK17O5ogAAAAZdEVYdENvbW1lbnQAQ3JlYXRlZCB3aXRoIEdJTVBXgQ4XAAAD6UlEQVRIx82WXWxTdRjGf6fndO3adbZ0VLoP9gFMXZQFNgSWDEkEYtSQkNVg4o2JH9NGJTMk6k01vTIhXshFzTCKE5NFORoXXDBs4nTMZHMzSETHDKyQyb7Xbu36dc7p8aaQZm5GNzd8rk7evOf%2fz%2fM%2bz%2f99X4E1htcn68v5742mffVRJd19uucqH539lSq3yKuHtlDmkPj99aPYe39kfRoMOqgCJHSdJNRL3AEE%2fB7h3xZFgO6JuRQdl6PE8zfRPzlF71CEojoXFc%2b9SPy3KxjCc%2bgCpIE0IilB65YWHFQBfAbUZEIDQGPA7xngDsNgMpFUY0Q0ESHHhKbkM3A9yoFqDceGQpTijWjhXxCAtC6gCWk0BAwLzqkAQsC6TJVDGcKrZdeDXp%2fcvki8zeuTH8uO6ehYzRJumxEUBUkyMa%2baUDWBVDLNnJJgNE9ixGZiOlckaQAVAWmBdTqBzqxQJ%2fD2KgrTCDzq9clywO%2fxZMi1AgcBBbhNPhyJ47TlsGuzjaHRSRRdoKq8AF3XOdvZw1BMQneUMl9iZN4eo3AmRWVwFulvqusAngBOryLBY0AcaPD65LeAFPAk0BLwe57OTnz3i4sc3ruFx2s24MwzoWgaW4tNnPn0JLt37KJ2zwGMgk5X3zd8ONJOX7mGvcK5OEGvT94HNGcs2rjSzrhUUwn4PV1AV4bcm5nwkYDfc3xhbs%2bVWQZH%2btlekc%2fDtRupKrub1uYT7NhWw9bde%2fl2REUSRR56pJT0lxofhM8xaheXVPA1oDPg9zT%2bExmsDqF8hUqmlvi%2bDUs6RWhW5Ov%2bKaxmK5XFLkIzIe7f%2fiBtwypPVZqIRWJ8Ny6x09OEJJs5rrTxn4yJY00NwRU0mtaMLY9kyL3n9clVAb%2fnley8wnyBkkIHrgILm925JGPTJONRDHqaHDQmx2a4Ph4hpFkpcZqZmBhHtbI4wYDfs3%2bNhn5bpqG03LKl1ydXAS97fXJ%2b9jv0Hq6lyK5C%2fBJ6PEjyj2nW2VQGLw5gLKqn92YSxWgjbrRy89ogVosFoyT%2bZUzcurjD65M71oDjCeDzbCIZ5VqAk9mJm9w5zAdPkRx%2bB3H6Y3Kj7TxQMkzLqfe5V71GvttFiduOa3aQc58E6JseJJXSEVhjeH2yvpxN5qVnygj%2fdJQCWxjBAOm0gVRC5MLPdoZnt2F3rsdisTAV7MBlusT3oVK6TOriCv4fIZnsSDlu1IQRNWVGV83kYKFuZzX7PQ1MFOg0j53nh%2bg8qpLg2eogeyJ53JFddDkLtyiZ6%2b%2b674Vu5cZXiIkJdAEMjnvIqzjEjVCS7rmrhOwC0Vwn58fqkIIXeL72Mn8CJn6UfKGeNt4AAAAASUVORK5CYII%3d);
<!------ Above sample from web logs -------------->

Encoded Red Dot Example

Red dot
Red Dot Above?

HTML Code for the Red Dot Above

<p style=”text-align: center;”><img src=”data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAABGdBTUEAALGP C/xhBQAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9YGARc5KB0XV+IA AAAddEVYdENvbW1lbnQAQ3JlYXRlZCB3aXRoIFRoZSBHSU1Q72QlbgAAAF1J REFUGNO9zL0NglAAxPEfdLTs4BZM4DIO4C7OwQg2JoQ9LE1exdlYvBBeZ7jq ch9//q1uH4TLzw4d6+ErXMMcXuHWxId3KOETnnXXV6MJpcq2MLaI97CER3N0 vr4MkhoXe0rZigAAAABJRU5ErkJggg==” alt=”Red dot” />

(Above code from Wikipedia link – check there for additional examples.)

Topics: System and Network Security, Web Problem Solving, Web Technologies | Comments Off on Google errors: url(data:image/png;base64…???

GeoIP origins of malicious network activity

By Dale Reagan | April 28, 2013

I have previously written that GeoIP data is not a reliable source for definitive data analysis – it is, however, a reasonable indicator.  The numbers below are from a single server (logged during the past few years) and don’t really provide any surprises.  Some things to keep in mind:

In early 2013 there have been numerous ‘news stories’ about hacking from China.   The numbers below are cumulative (based on several years of data.)  One of the interesting pieces of data (if you dig a bit) is that you find many US IP locations (GeoIP) are for ‘data centers’ (ISPs with large numbers of servers and significant IT infrastructure) that appear to be ‘hosting’ connections/domains/servers for China-based entities (as well as other from other countries) from which hacking attacks appear to be launched.  The numbers would be higher if  I did not use firewall rules (along with mod_security, mod_geoip, milter-greylist) to block access from troublesome IP space.)

GeoIP Sources of Ssh Connection Attempts – Top 10 Countries

        *********** Unique # of Countries_CNT:_124 ***********
  1.    1120 | CN
  2.     868 | US
  3.     225 | KR
  4.     181 | DE
  5.     181 | CA
  6.     151 | BR
  7.     136 | IN
  8.     108 | FR
  9.     106 | IT
 10.      99 | GB

GeoIP Sources of Ssh Connection Attempts – Top 10 Cities

        *********** Unique # of Cities_CNT:_1177 ***********
  1.     225 | Beijing
  2.     135 | Seoul
  3.     114 | Guangzhou
  4.      62 | Shanghai
  5.      54 | Taipei
  6.      49 | Hangzhou
  7.      48 | Nanjing
  8.      48 | Dallas
  9.      41 | Paris
 10.      37 | San_Antonio

Fake ‘Bots’ & GeoIP data

A related issue that I started tracking is ‘fake bots’ – web server connections that suggest they are from ‘legitimate bots’, but, when you review the IP data (GeoIP or DNS information) you will find that the bot is NOT related to the ‘bot domain’ (i.e. GoogleBot.)   The numbers below are from ‘fake’ Google Bots – my data starts in 2010:

      | # Fake | GeoIP Country
    1 |   4145 | BR
    2 |    399 | TR
    3 |    369 | PT
    4 |     95 | ES
    5 |     85 | IT
    6 |     84 | FR
    7 |     68 | UA
    8 |     60 | MX
    9 |     50 | US
   10 |     38 | RU

Fake Google Bots per year:

So, what are these ‘fake bots’ doing?

I’m guessing that ‘fake bots’ are visiting your sites for two primary reasons:

  1. scraping your site (which is then re-published on bogus, totally automated web sites which are used to generate web traffic and earn revenue – these fake sites can  ‘pollute’ the major search engines; if your web site is supported by search engine ads then this, of course, reduces your revenue…
  2. attempting to create SEO traffic from web sites that ‘publish’ their web server logs.

Overall, the scope and sources of malicious, nefarious or ‘bad’ server traffic show no GeoIP limitations – but the data above does suggest ‘hot spots’ for the ‘bad guys’..

So what?  I suggest reviewing the GeoIP data for all of your server logs – at this point, the results should NOT be surprising; Once you identify/understand the ‘data patterns’ then you can create your own automated solution(s) to deal with these types of network/server issues. Your arsenal is unlimited but a starting point is to use/configure tools like:

And yes, I can (and do) manually ‘block’ bad IP space – but, most of what I do has been automated using standard *NIX tools – I just review the logs/system to make sure it continues to ‘work’.

As always, your mileage will vary… 🙂

Topics: Computer Technology, System and Network Security, Unix-Linux-Os | Comments Off on GeoIP origins of malicious network activity

Fedora 18 (Linux)

By Dale Reagan | April 12, 2013

Fedora 18 Released January 2013

Always 1st – Big ‘hats off’ to Open Source and folks contributing/refining/supporting/moving-forward!  My comments reflect a ‘gut reaction’ to what I am seeing/encountering – and I do expect others to both share and hold different views.

Ok, I put off moving ‘up’ from FC 13/14 since the introduction of the latest Version of the GNOME Desktop – which I do no care for since:

Other dis-likes:

My steps to creating a ‘useable’ Fedora 18 Setup

  1. install as web server
  2. login as ‘root’ & add desired users with sudo access
  3. setup a local, DVD Repo
  4. install desired X-related interfaces
  5. tweek & test
  6. Yum is broken – well, in my case my network config was not allowing DNS queries from this new system (imaging that!)  I was getting errors about ‘bad meta-links’ – try a simple ‘ping remote_host’ – if if fails check your network firewall…  In my case I configured Yum to use a proxy (see below.)

Setting a local DVD Report for Fedora 18

NOTE – ‘root’ level access required for most of these steps.

Create a folder and Mount your Fedora DVD:

  1. mkdir /media/DVD
  2. mount /dev/sr0 /media/DVD

Create a local repo:

  1. vim /etc/yum.repos.d/fc18-dvd.repo
  2. add the text below, then save and exit:

name=FC 18 Installation DVD

  1. check all available repos:
    • yum repolist
  2. check your new local repo making sure to exclude other repos:
    •  yum –disablerepo=* –enablerepo=dvd list available
  3. review the list – should be everything on your DVD
  4. select packages for install and manually install them via:
    • yum install packagename

Manually installing X-Windows Desktops via Yum

If you did your initial install via DVD the you will probably recalling seeing a list similar to the one below. The command to list ‘groups’ is (note that your output will most likely vary):

 yum –disablerepo=* –enablerepo=dvd grouplist
Loaded plugins: langpacks, presto, refresh-packagekit
Available Environment Groups:
GNOME Desktop
KDE Plasma Workspaces
Xfce Desktop
LXDE Desktop
Sugar Desktop Environment
Development and Creative Workstation
Web Server
Infrastructure Server
Minimal Install
Installed Groups:
Design Suite
Development Tools
Fedora Eclipse
Network Servers

Ok, we want to install ‘X’ – you could do everything manually but it’s simpler to install a group, which, in theory should grab everything needed to run your desired GUI.  Some examples:

Another tweak – configure Yum to use a proxy:

vim /etc/yum.conf ## add the relevant lines below using your Proxy_Server (or IP and port)

# The proxy server – proxy server:port number
# The account details for yum connections

Once installed, AND, since we require a ‘terminal login’ before starting the GUI, you have to know which command(s) to use; this will vary based on which GUIs you have installed; they are typically located in /bin:

 ls -l /bin/start* | grep -v -e pulse|awk ‘{printf “%3d. %s\n”, NR, $0}’

  1.  -rwxr-xr-x. 1 root root  1313 Jul 20  2012 /bin/startlxde
  2.  -rwxr-xr-x. 1 root root  2968 Sep 30 14:57 /bin/startxfce4
  3.  -rwxr-xr-x. 1 root root  5084 Oct  1 19:11 /bin/startx
  4.  -rwxr-xr-x. 1 root root 12298 Dec  6 12:00 /bin/startkde

In this case I am using ‘startxfce4’ or ‘startkde’ – I simply type one of those commands after logging in.  NOT – you may have to manually ‘configure X’ before using you freshly installed GUI..

FC 18 With VNC Server for the Console

Getting this to work was a bit of a ‘chore’…  The approach with Fedora 16-18 has been to modify ‘traditional’ setups to use ‘systemd’ – a ‘new’ way of managing the system.  This and other changes make it a tad cumbersome to use some tools/programs that I become accustomed to taking advantage of (i.e. my ‘test’ system is across the room and I want to work on the console without leaving my desk..)  The complexities of the X-Window system are legion – the nicely wrapped functionality of Fedora 18 required some digging to find a solution (sharing the console via VNC…)  The snippets below are from this post covering FC 16 and VNC.

Note that you may need to install these tools (i.e. yum install vino-server.)

$ /usr/libexec/vino-server

To automatically start vino-server every time you login to XFCE, go to “Application Menu > Settings > Session and Startup > Application Autostart” and add an application entry for /usr/libexec/vino-server


You can access the preferences window in XFCE by running the command through a terminal or through the Run prompt.

$ vino-preferences

You may also have to place a .desktop file for vino into the ~/.config/autostart directory as XFCE may not start it for you.

Another approach/solution is discussed here:

Install the required packages:

Steps to access the Console display using VNC:

x11vnc -auth <homedir of the user who logged to console X session>/.Xauthority -display:0
Note: You must have read permission for the .Xauthority file of the user who logged into the X session
x11vnc -auth /var/gdm/:0.Xauth -display :0

Running the System without ‘run-levels’

Since /etc/inittab is essentially gone you are forced to use ‘symlinks with files’ (I think this is quite cumbersome and certainly not nearly as simple as editing a configuration file…)’; Switching between  a Gui startup and a terminal startup is possible but I will simply login via a terminal session and then manually start X-Windows using the Gui of choice.  BTW – seems that ‘run-levels’ are still reported:

# who -r
run-level 3  2013-01-21 18:40

Ok, after install the base web server AND tweaking Yum it’s time to check – how many updates do I need:

yum update

On this system I get back a list of 400+ programs (~700MB)  needing an ‘update’.

At this point, after ~10 years not so sure that I will be coming back to Fedora – too many ‘changes for change sake’ vs ‘changing to something_new since it is mega-better….’

Topics: Problem Solving, System and Network Security, Unix-Linux-Os | Comments Off on Fedora 18 (Linux)

« Previous Entries Next Entries »

YOUR GeoIP Data | Ip:
Continent: NA | Country Code: US | Country Name: United States
Region: | State/Region Name: | City:
(US only) Area Code: 0 | Postal code/Zip:
Latitude: 38.000000 | Longitude: -97.000000
Note - if using a mobile device your physical location may NOT be accurate...

Georgia-USA.Com - Web Hosting for Business