Systems Librarianship
Author: C. Sean Burns
Date, version 2: 2024-04-01
Email: sean.burns@uky.edu
Website: cseanburns.net
GitHub: @cseanburns
Introduction
The goal of this book is to provide a technical introduction to the basics of systems librarianship using Linux. The book is used alongside a course on systems librarianship that the author teaches.
The course and book goals include:
- how to use the Linux command line in order to become more efficient computer users and more comfortable with using computers in general;
- how to use cloud computing resources and create virtual machines;
- how to manage projects using Git and GitHub;
- how to create a LAMP server, websites, and create a bare bones OPAC;
- how to install and configure content management systems, and;
- how to install and configure an integrated library system.
- to foster self-efficacy with computers and an enthusiasm for foundational computer technologies
About This Book
The Systems Librarianship course is a brand new course (2023). I created the course to help future and current librarians become proficient in the kinds of technology used to manage and provide electronic resources.
Since I use this book for my Systems Librarianship course, which I will likely teach each spring semester, this book will be a live document. Each semester that I teach this course, I will update the content in order to address changes in the technology and to edit for clarity when I discover some aspect of the book causes confusion or does not provide enough information.
A small part of this book will draw from my course on Linux Systems Administration, which I teach in the fall semesters.
This book is not a comprehensive introduction to systems librarianship. For example, this book does not cover software coding nor managerial duties, like issuing requests for proposals for software products, or budgeting. It is designed as an entry level course in the technical aspects of systems librarianship, and it is meant to go hand-in-hand with other courses taught in our program. That includes my course on electronic resource management but also other courses that my colleagues teach.
I am using mdBook to build this work. Please use the search function on this site to search for specific topics or keywords. If the reader desires a PDF copy of this work, the printer icon at the top right of the page will print to PDFs.
The content in this book is open access and licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 4.0 license. Feel free to fork it on GitHub and modify it for your own needs.
History of Unix and Linux
An outline of the history of Unix and Linux.
Note: this section is borrowed from my Linux Systems Administration course.
Location: Bell Labs, part of AT&T (New Jersey), late 1960s through early 1970s
In the late 1960s through the early 1970s at Bell Labs, part of AT&T in New Jersey, the journey began with an operating system called Multics. Multics was a pioneering time-sharing system, allowing more than one person to use it at once. Despite its innovative approach, Multics was fraught with issues and was slowly abandoned. In the midst of this abandonment, Ken Thompson stumbled upon an old PDP-7 and started writing what would become UNIX. During this time, he created the ed line editor, pronounced e.d., but generally sounded out. This specific version of UNIX would later be known as Research Unix. The project caught the attention of Dennis Ritchie, the creator of the C programming language, who joined Thompson's efforts, and together they laid the groundwork for a revolution in computing.
Location: Berkeley, CA (University of California, Berkeley), early to mid 1970s
In the early to mid-1970s at the University of California, Berkeley, the evolution of UNIX continued. While not classified as 'free software,' UNIX's code was low-cost and easily shared among tech enthusiasts. Ken Thompson visited Berkeley, where he helped install Version 6 of UNIX, marking a significant moment in the system's history. At Berkeley, several contributors, including Bill Joy, played vital roles in its development. Joy was particularly influential, creating the vi text editor, a precursor of the popular Vim editor, and many other essential programs. He also co-founded Sun Microsystems. This installation and collaborative effort at Berkeley eventually led to the creation of the Berkeley Software Distribution, or BSD, a landmark in the history of UNIX and computing as a whole.
AT&T
Until its breakup in 1984, AT&T operated under a unique agreement with the U.S. government that restricted the company from profiting off patents not directly related to its telecommunications businesses. This arrangement helped shield AT&T from monopolistic charges, but it also came with a significant limitation: they could not commercialize UNIX. The landscape changed dramatically after the breakup of AT&T. The constraints lifted, allowing System V UNIX to emerge as the standard bearer of commercial UNIX. This transition marked a turning point in the history of computing, positioning UNIX as a central player in the commercial technology market.
Location: Boston, MA (MIT), early 1980s through early 1990s
In Boston, MA, at MIT during the early 1980s through the early 1990s, a significant shift in the software industry was taking place. In the late 1970s, Richard Stallman observed the growing trend of software becoming commercialized. This commercialization led to hardware vendors ceasing to share the code they developed to make their hardware work. This paradigm change was further solidified by the Copyright Act of 1976, making software code eligible for copyright protection. Stallman, who thrived in a hacker culture, began to battle against this new direction. He responded by creating the GNU project, embracing the free software philosophy, and developing influential tools such as GNU Emacs, a popular text editor, and many other programs. The GNU project was an ambitious attempt to create a completely free software operating system that was Unix-like, called GNU. By the early 1990s, Stallman and others had developed all the utilities needed for a full operating system, except for a kernel, which they named GNU Hurd. This encompassing project included the creation of the Bash shell, written by Brian Fox, reflecting a profound commitment to free and open software.
The GNU philosophy includes several propositions that define free software:
The four freedoms, per GNU Project: 0. The freedom to run the program as you wish, for any purpose (freedom 0).
- The freedom to study how the program works, and change it so it does your computing as you wish (freedom 1). Access to the source code is a precondition for this.
- The freedom to redistribute copies so you can help others (freedom 2).
- The freedom to distribute copies of your modified versions to others (freedom 3). By doing this you can give the whole community a chance to benefit from your changes. Access to the source code is a precondition for this.
The Unix wars and the lawsuit, late 1980s through the early 1990s
During the late 1980s through the early 1990s, the so-called "Unix wars" and an ensuing lawsuit marked a contentious period in the history of computing. Following its breakup, AT&T began to commercialize Unix, leading to distinct differences between AT&T Unix and BSD Unix. The former was aimed at commercial markets, while the latter was targeted at researchers and academics. These contrasting objectives led to legal friction, culminating in UNIX Systems Laboratories, Inc. (USL, part of AT&T) suing Berkeley Software Design, Inc. (BSDi, part of the University of California, Berkeley) for copyright and trademark violations. Ultimately, USL lost the case, but not before the lawsuit had created significant obstacles for BSD Unix. The legal battle delayed the adoption of BSD Unix, leaving a lasting impact on the development and dissemination of Unix systems.
Linux, Linus Torvalds, University of Helsinki, Finland, early 1990s
In the early 1990s at the University of Helsinki in Finland, a significant development in the world of computing unfolded. On August 25, 1991, Linus Torvalds announced that he had started working on a free operating system kernel specifically for the 386 CPU architecture and his hardware. This kernel would later be famously named Linux. It's essential to understand that Linux technically refers only to the kernel, which handles startup, devices, memory, resources, and more, but does not provide user land utilities—the kind of software that people use on their computers.
Torvalds' motivation for this project was both to learn about OS development and to have access to a Unix-like system. He already had access to an Unix-like system called MINIX, but MINIX was limited by technical and copyright restrictions. Interestingly, Torvalds has stated that if a BSD or GNU Hurd operating system were available at that time, he might not have created the Linux kernel at all. However, he and others took the GNU utilities and created what is now widely referred to as Linux or GNU/Linux. This amalgamation of Torvalds' kernel and GNU utilities marked a critical point in the evolution of free and open-source software, fostering a global community of developers and users.
Distributions, early 1990s through today
Soon after the development of Linux in the early 1990s, a trend began to emerge that continues to this day. Enthusiasts and developers started creating their own Linux and GNU-based operating systems, customizing them to suit various needs and preferences. They would then distribute these customized versions to others, sharing their innovations and insights with a wider community. As a result of this practice, these Linux operating systems became known as "distributions." This phenomenon has led to a rich ecosystem of Linux distributions, catering to different user bases, industries, and interests, and has played a central role in the continued growth and diversification of open-source computing.
The two oldest distributions that are still in active development include:
Short History of BSD, 1970s through today
The history of Berkeley Software Distribution (BSD) spans from the 1970s to today and is closely intertwined with the evolution of Unix. Early Unix version numbers 1-6 eventually led to the development of BSD versions 1-4. By the time of BSD 4.3, all versions still contained some AT&T code. A desire to remove this proprietary code led to the creation of BSD Net/1.
The effort continued until all AT&T code was successfully removed by BSD Net/2. This version was then ported to the Intel 386 processor, resulting in 386BSD, made available in 1992, a year after the Linux kernel was released.
386BSD eventually split into two distinct projects: NetBSD and FreeBSD. Later, NetBSD itself split into another project, giving rise to OpenBSD. All three of these BSDs are still in active development today, and each has a unique focus:
- NetBSD is known for its focus on portability, finding applications in various environments such as MacOS and even NASA projects.
- FreeBSD is recognized for its wide applicability and has been utilized by notable companies and products like WhatsApp, Netflix, PlayStation 4, and MacOS.
- OpenBSD emphasizes security and has contributed several essential applications in this domain.
This intricate journey of BSD, marked by splits, adaptations, and varied focuses, has cemented its place in the history of operating systems, allowing it to cater to a wide range of applications and audiences.
MacOS is based on Darwin, is technically UNIX, and is partly based on FreeBSD with some code coming from the other BSDs. See Why is macOS often referred to as 'Darwin'? for a short history.
Short History of GNU, 1980s through today
The history of GNU, particularly the GNU Hurd kernel, traces back to the 1980s and continues to evolve today. The GNU Hurd, despite its long development process, remains in a pre-production state. The latest release of this kernel was version 0.9, which came out in December 2016. Even though it has not yet reached full maturity, a complete operating system based on the GNU Hurd can be downloaded and run. For example, Debian GNU/Hurd represents one such implementation. This ongoing work on the GNU Hurd exemplifies the free and open-source community's commitment to innovation and collaboration, maintaining a spirit of exploration that has driven the software landscape for decades.
Free and Open Source Licenses
In the free software and open source landscape, there are several important free and/or open source licenses that are used. The two biggest software licenses are based on the software used by GNU/Linux and the software based on the BSDs. They each take very different approaches to free and/or open source software. The biggest difference is this:
- Software based on software licensed under the GPL must also be licensed under the GPL. This is referred to as copyleft software, and the idea is to propagate free software.
- Software based on software licensed under the BSD license may be closed source and primarily must only attribute the original source code and author.
What is Linux?
The Linux Kernel
Technically, Linux is a kernel, and a kernel is a part of an operating system that oversees CPU activity like multitasking, as well as networking, memory management, device management, file systems, and more. The kernel alone does not make an operating system. It needs user land applications and programs, the kind we use on a daily basis, to form a whole, as well as ways for these user land utilities to interact with the kernel.
Linux and GNU
The earliest versions of the Linux kernel were combined with tools, utilities, and programs from the GNU project to form a complete operating system, without necessarily a graphical user interface. This association continues to this day. Additional non-GNU, but free and open source programs under different licenses, have been added to form a more functional and user friendly system. However, since the Linux kernel needs user land applications to form an operating system, and since user land applications from GNU cannot work without a kernel, some argue that the operating system should be called GNU/Linux and not just Linux. This has not gained wide acceptance, though. Regardless, credit is due to both camps for their contribution, as well as many others who have made substantial contributions to the operating system.
Linux Uses
We are using Linux as a server in this course, which means we will use Linux to provide various services. Our first focus is to learn to use Linux itself, but by the end of the course, we will also learn how to provide web and database services. Linux can be used to provide other services that we won't cover in this course, such as:
- file servers
- mail servers
- print servers
- game servers
- computing servers
Although it's a small overall percentage, many people use Linux as their main desktop/laptop operating system. I belong in this camp. Linux has been my main OS since the early 2000s. While our work on the Linux server means that we will almost entirely work on the command line, this does not mean that my Linux desktop environment is all command line. In fact, there are many graphical user environments, often called desktop environments, available to Linux users. Since I'm currently using the Ubuntu Desktop distribution, my default desktop environment is called Gnome. KDE is another popular desktop environment, but there are many other attractive and useful ones. And it's easy to install and switch between multiple ones on the same OS.
Linux has become quite a pervasive operating system. Linux powers the hundreds of the fastest supercomputers in the world. It, or other Unix-like operating systems, are the foundation of most web servers. The Linux kernel also forms the basis of the Android operating system and of Chrome OS. The only place where Linux does not dominate is in the desktop/laptop space.
What is Systems Administration?
Introduction
What is systems administration or who is a systems administrator (or sysadmin)? Let's start off with some definitions provided by the National Institute of Standards and Technology:
An individual, group, or organization responsible for setting up and maintaining a system or specific system elements, implements approved secure baseline configurations, incorporates secure configuration settings for IT products, and conducts/assists with configuration monitoring activities as needed.
Or:
Individual or group responsible for overseeing the day-to-day operability of a computer system or network. This position normally carries special privileges including access to the protection state and software of a system.
See: Systems Administrator @NIST
Specialized Positions
In addition to the above definitions, which broadly define the role, there are a number of related or specialized positions. We'll touch on the first three in this course:
- Web server administrator:
- "web server administrators are system architects responsible for the overall design, implementation, and maintenance of Web servers. They may or may not be responsible for Web content, which is traditionally the responsibility of the Webmaster (Web Server Administrator" @NIST).
- Database administrator:
- like web admins, and to paraphrase above, database administrators are system architects responsible for the overall design, implementation, and maintenance of database management systems.
- Network administrator:
- "a person who manages a network within an organization. Responsibilities include network security, installing new applications, distributing software upgrades, monitoring daily activity, enforcing licensing agreements, developing a storage management program, and providing for routine backups" (Network Administrator @NIST).
- Mail server administrator:
- "mail server administrators are system architects responsible for the overall design and implementation of mail servers" (Mail Server Administrators @NIST).
Depending on where a system administrator works, they may specialize in any of the above administrative areas, or if they work for a small organization, all of the above duties may be rolled into one position. Some of the positions have evolved quite a bit over the last couple of decades. For example, it wasn't too long ago when organizations would operate their own mail servers, but this has largely been outsourced to third-party providers, such as Google (via Gmail) and Microsoft (via Outlook). People are still needed to work with these third-party email providers, but the nature of the work is different than operating independent mail servers.
Certifications
It's not always necessary to get certified as a systems administrator to get work as one, but there might be cases where it is necessary; for example, in government positions or in large corporations. It also might be the case that you can get work as an entry level systems administrator and then pursue certification with the support of your organization.
Some common starting certifications are:
Plus, Google offers, via Coursera, a beginners Google IT Support Professional Certificate that may be helpful.
Associations
Getting involved in associations and related organizations is a great way to learn and to connect with others in the field. Here are few ways to connect.
LOPSA, or The League of Professional System Administrators, is a non-profit association that seeks to advance the field and membership is free for students.
ACM, or the Association for Computing Machinery, has a number of relevant special interest groups (SIGs) that might be beneficial to systems administrators.
NPA, or the Network Professional Association, is an organization that "supports IT/Network professionals."
Codes of Ethics
Systems administrators manage computer systems that contain a lot of data about us and this raises privacy and competency issues, which is why some have created code of ethics statements. Both LOPSA and NPA have created such statements that are well worth reviewing and discussing.
- LOPSA: Code of Ethics
- NPA: Code of Ethics
Keeping Up
Technology changes fast. In fact, even though I teach this course about every year, I need to revise the course each time, sometimes substantially, to reflect changes that have developed over short periods of time. It's also your responsibility, as sysadmins, to keep up, too.
I therefore suggest that you continue your education by reading and practicing. For example, there are lots of books on systems administration. O'Reilly continually publishes on the topic. RedHat, the makers of the Red Hat Linux distribution, and sponsors of Fedora Linux and CentOS Linux, provides the Enable Sysadmin site, with new articles each day, authored by systems administrators, on the field. Opensource.com, also supported by Red Hat, publishes articles on systems administration. Command Line Heroes is a fun and informative podcast on technology and sysadmin related topics. Linux Journal publishes great articles on Linux related topics.
Conclusion
In this section I provided definitions of systems administrators and also the related or more specialized positions, such as database administrator, network administrator, and others.
I provided links to various certifications you might pursue as a systems administrator, and links to associations that might benefit you and your career.
Technology manages so much of our daily lives, and computer systems store lots of data about us. Since systems administrators manage these systems, they hold a great amount of responsibility to protect them and our data. Therefore, I provided links to two code of ethics statements that we will discuss.
It's also important to keep up with the technology, which changes fast. The work of a systems administrator is much different today than it was ten or twenty years ago, and that surely indicates that it could be much different in another ten to twenty years. If we don't keep up, we won't be of much use to the people we serve.
What is Systems Librarianship
Introduction
Of course, let's begin with the question, what is systems librarianship? Normally we might go to the literature to answer a question like this. Indeed, the literature is helpful, but it's sparse. The LISTA database only returns 131 results with a 45 year coverage for a search using the thesauri term SYSTEMS Librarians. I can get more results if I expand the search query, but then I get less relevant results, and the main idea is the same: this is an understudied area of librarianship.
It's been that way for a while. Susan K. Martin wrote the following over 35 years ago:
Of the specialist positions that exist in libraries, none is as underexamined as those of the systems librarians---the people who identify the needs of the library for automated systems, cause these systems to be implemented, and analyze the operations of the library (p. 57).
Perhaps as a result of this underexamination, sometimes there is confusion around the requirements and skills needed in this area of librarianship. Martin (1988) captured this tension when she wrote the following in 1988, which is still true today:
Over the years the library world has argued whether systems librarians should be librarians who have learned information technologies, or computer experts who have learned about libraries (p. 61).
The argument is partly a matter of jurisdiction. Abbott (1998), writing on librarianship in the sociology of professions, illustrated how:
The future of librarianship thus hinges on what happens to the perpetually changing work of the profession in its three contexts: the context of larger social and culture forces, the context of other competing occupations, and the context of competing organizations and commodities. To these complex contextual forces, any profession responds with varying policies and internal changes (pp. 434-5).
Essentially, Abbott means that professions, like librarianship, are always changing. The mechanisms for that change are structural and cultural (Abbott, 2010), but a changing profession means that its "link of jurisdiction" (Abbott, 1998, p. 435) changes, too. It not only changes, but professions constantly compete with each other over to adopt new areas of jurisdiction. So when we ask, as Martin (1998) did, whether librarians should learn information technologies or whether computer experts should learn libraries, I find myself thinking the prior is more important for libraries and their patrons. It means that librarians are expanding their jurisdiction by also becoming computer experts rather than computer experts expanding theirs.
That leads us to the next questions: what does it mean to be a computer expert for a systems librarian? What does a systems librarians need to do and know?
The answer is that it is a mix. Some part of the work involves systems administration, but that has broad meanings, and systems librarianship is more specific. Or, it has a more specific domain: the domain of libraries and librarianship.
A systems librarian might thus be considered a library systems administrator. Under this view, they need to be someone who knows about libraries, how libraries work, what they do, about their patrons, what their values are, and then use that knowledge to build the infrastructure to support that.
Given this, and the technologies involved, such work requires constant learning. Jordan (2003) identified three areas of learning:
- pre-service education in library schools
- on the job training
- professional development in the form of workshops, courses, and conferences (p. 273)
Pre-service, formal education is a small part of any professional's career, regardless if that profession is in medicine, law, or librarianship. Thus the goal of pre-service education is to prepare people to adapt and grow in their fields. Jordan (2003) wrote that:
While formal training is undoubtedly important, the ability to learn new technologies independently lies at the foundation of systems librarians' professional life, because they often have to use technologies, or make planning decisions about specific technologies, before they become common enough to be the subject of formal training sessions (p. 273).
Even though Jordan's article is 20 years old and the technology has changed a lot, the basic duties of the systems librarian remain the same (Fu, 2014; Gonzales, 2020). Wilson (1998), as cited in Jordan (2003), refers to a list of the "typical responsibilities of systems librarians." These responsibilities look different today, because the technology is different, but conceptually, they're the same as they were then. In fact, this work will focus on a subset of this list that includes:
- integrated library system management
- server management
- documentation
- technology exploration and evaluation (Jordan, 2003, p. 274)
Gonzales (2020) highlights these and more current areas that include:
- content management systems
- electronic resource management systems
- website redesign
- help and support
Other items on Jordan's (2003) list are still relevant, but due to various constraints, this work will not cover the following areas:
- network design and management
- desktop computing
- application development
- planning and budget
- specification and purchasing
- miscellaneous technology support
- technical risk management (p. 274)
In short, this work specifically focuses on a few of the bigger technical aspects of systems librarianship. Other works (or courses) and other sources will provide learning opportunities on the more managerial and administrative functions of systems librarianship and librarianship, in general.
If you are interested in learning more about network design and administration, then I encourage you to read my chapters on Networking and TCP/IP and DNS and Domain Names in my book on Systems Administration with Linux.
If you are interested in learning about application development, then you can pursue courses in a variety of programming languages, such as R, Python, JavaScript, and PHP, as well as courses on relational databases, such as MySQL or PostgreSQL, and so forth.
As Jordan (2003) identified, there is a lack of formalized training in systems librarianship in LIS schools. This is as true today as it was in 2003. This course was created to address the lack of that training. However, as Jordan (2003) noted, pre-service education is only a start. Technology is constantly changing, and that means we must always embrace learning opportunities, such as through workshops, conferences, and on the job training. LIS programs are only two or so years long (if attending full time), but our careers will hopefully span decades. So all this course can ever be is just a starting point.
It is a big start, though. This course should lay a strong foundation for self-growth and self-education in the variety of technologies that we will learn and use here. Although separate areas of librarianship, my work (and course) on electronic resource management complement this one in many ways. For example, this work supports several parts of the technology section in the NASIG Core Competencies for Electronic Resources Librarians. It is no coincidence these two areas of librarianship often overlap or are assumed in a single librarian position.
Cloud Computing
Lastly, I want to mention cloud computing. This has become a major area of change in the last decade or so. It used to be more common for librarians to install their integrated library system software and store their bibliographic data on their premises. In the last ten years, there has been more migration to the cloud, which means that both the integrated library system software and the bibliographic data are stored off-site. Liu & Cai (2013) highlight the beginning of this trend toward cloud computing that continues to play a large role in systems librarianship (Naveed et al., 2021). As Liu and Cai note:
Systems librarians used to make their livings by managing hosted library systems. This situation is silently changing with the library systems moving onto the cloud (p. 26).
This trend has changed some aspects of systems librarianship. It means that systems librarians, while still a technical area of librarianship, need to work more closely with the vendors who themselves are hosting library systems. However, the trend does not erase all locally hosted solutions. Many libraries and other information agencies continue to support local collections and will either host those locally or work to get the bibliographic information for those collections ingested into their cloud-based integrated library systems.
Conclusion
The remainder of the course
will be more technical and
will prepare you to work and understand the
systems that support the modern library.
We will cover a lot, too!
We will begin with setting up
virtual machine instances on Google Cloud.
We will use a distribution of the Linux
operating system for these virtual machines.
We will then learn the basics of the
Linux command line.
Next, we will learn how to use
the version control system called git
.
We will use git
to document our work flows and
push that documentation to GitHub.com.
On our Linux servers,
we will create a web server out of
what is called a LAMP stack,
which stands for
Linux,
Apache,
MySQL, and
PHP.
We will use the web server
to setup a basic website and
a bare bones OPAC.
(I'll provide the code for this.)
Then we will learn how to install
and setup two content management systems:
Wordpress and Omeka.
Lastly, we will spend the final
two weeks of the semester
installing and setting up the
open source Koha ILS.
Let's get started!
References
Abbott, A. (1998). Professionalism and the future of librarianship. Library Trends, 46(3), 430–443. https://www.proquest.com/docview/220452054/abstract/A48FC30B10D94886PQ/1?accountid=11836
Abbott, A. (2010). Varieties of ignorance. The American Sociologist, 41(2), 174–189. https://www.jstor.org/stable/40664150
Gonzales, B. M. (2020). Systems librarianship: A practical guide for librarians. Rowman & Littlefield Publishers. https://rowman.com/ISBN/9781538107133/Systems-Librarianship-A-Practical-Guide-for-Librarians
Fu, P. (2014). Supporting the next-generation ILS: The changing roles of systems librarians. Journal of Library Innovation, 5(1), 30–42.
Jordan, M. (2003). The self‐education of systems librarians. Library Hi Tech, 21(3), 273–279. https://doi.org/10.1108/07378830310494445
Liu, W., & Cai, H. (Heather). (2013). Embracing the shift to cloud computing: Knowledge and skills for systems librarians. OCLC Systems & Services: International Digital Library Perspectives, 29(1), 22–29. https://doi.org/10.1108/10650751311294528
Martin, S. K. (1988). The role of the systems librarian. Journal of Library Administration, 9(4), 57–68. https://doi.org/10.1300/J111v09n04_06
Naveed, M. A., Siddique, N., & Mahmood, K. (2021). Development and validation of core technology competencies for systems librarian. Digital Library Perspectives, 38(2), 189–204. https://doi.org/10.1108/DLP-03-2021-0022
Ratledge, D., & Sproles, C. (2017). An analysis of the changing role of systems librarians. Library Hi Tech, 35(2), 303–311. https://doi.org/10.1108/LHT-08-2016-0092
Wilson, T. C. (1998). Systems librarian: Desinging roles, defining skills. American Library Association. https://www.worldcat.org/title/1038159656
Project Management
This course involves working towards a final project that will lead us to install two content management systems and an integrated library system.
To accomplish this, we will need to set up Linux servers. We will use Google Cloud for this purpose. With Google Cloud, we can create what are called virtual machines that run full-fledged operating systems. We will work with Linux, and in particular, the Ubuntu distribution of Linux, to complete our project.
We will also want
to document our work.
To do that,
we will use git,
which is a version control system,
and GitHub,
an online platform
for hosting git
repositories.
Using git
,
we can collaborate,
share documentation and code,
and more.
Using Google Cloud (gcloud)
The first section in this chapter introduces us to Google Cloud, which I'll often refer to as gcloud. We will use this platform to create virtual instances of the Ubuntu Server Linux operating system. Once we create our own Ubuntu virtual machines, we will connect to them via the command line. I have written some helpful software to help you learn the command line language, specifically, the Bash shell. Just about everything we'll do this semester will happen via the Bash shell.
Git and GitHub
The second section
in this chapter
introduces us to git
and GitHub.
git
and GitHub are
primarily used for software management.
Every major software project
requires managing the codebase,
collaborations,
documentation, and more.
Many people may be involved
in these projects,
and it takes coordination
for them to write
the many thousands of
lines of software code,
which also requires management.
Although git
and GitHub
are primarily used
for this purpose,
our goal is to use them
to document our work,
much like this book,
which has its own
GitHub repository or repo.
This documentation covers
the processes involved
in learning Google Cloud,
git
and GitHub, Linux, and more.
Therefore,
in the next section,
we'll learn how
to create a new repo on GitHub,
use the web interface to add notes,
and write our notes using Markdown,
an easy-to-understand and
use markup language to format our text.
Providing good documentation is key to being able to build on prior work, make adjustments to our workflows, recall the details of some process, and, for students, it can help in retention and reflection. In the remainder of the semester, we will begin to install and configure some complicated pieces of software. In order to better understand what we will be doing, it will be helpful to document our processes.
Attending to Detail
As we begin to work on the more technical aspects of this book and course, it will be important to remain attentive to details. Many people who are new to this kind of work often stumble over the details, like a missing period, incorrect capitalization, and more. To learn how to pay attention to the details, work slowly and read any messages, including error messages, the screen prints out in response to your commands.
Using gcloud for Virtual Machines
Virtual Machines
Our goal in this section is to create a virtual machine (VM) instance. A VM is basically a virtualized operating system that runs on a host operating system. That host operating system may also be Linux, but it could be Windows or macOS. In short, when we use virtual machines, it means instead of installing an operating system (like Linux, macOS, Windows, etc) on a physical machine, we use virtual machine software to mimic the process. The virtual machine, thus, runs on top of our main OS. It's like an app, where the app is a fully functioning operating system.
In this course, we're going to use gcloud (via Google) to provide us with virtual machines. There are other cloud service providers available that you can explore on your own. You can also play with VirtualBox (on your own), which I've used in prior classes, to install virtual machines on your own computers.
Google Cloud / gcloud
Google Account
We need to have a personal Google account to get started with gcloud. I imagine most of you already have a Google account, but if not, go ahead and create one at https://www.google.com.
Google Cloud (gcloud) Project
Next we will need to create a project on the Google Cloud website.
Follow Step 1 at the top of the Install the gcloud CLI page to create a new project. Also, review the page on creating and managing projects.
When you create your project, you can name it anything, but try to name it something to do with this course. E.g., I am using the name syslib-YEAR (replace YEAR with the actual year). Avoid using spaces when naming your project.
Then click on the Create button, and leave the organization field set to No Organization.
Google Billing
The second thing to do is to set up a billing account for your gcloud project. This does mean there is a cost associated with this product, but the good news is that our bills by the end of the semester should only amount to $5 to 10 dollars, at most. Follow Step 2 to enable billing for your new project. See also the page on how to create, modify, or close your self-serve Cloud Billing account.
At the end of the semester, I'll remind you that you may want to delete your virtual machines. If you don't do this, you will continue to be billed for them.
Install the latest gcloud CLI version
After you have set up billing, the next step is to install gcloud on your local machines. The Install the gcloud CLI page provides instructions for different operating systems.
There are installation instructions for macOS, Windows, Chromebooks, and various Linux distributions. Follow these instructions closely for the operating system that you're using. Note that for macOS, you have to choose among three different CPU/chip architectures. If you have an older macOS machine (before November 2020 or so), it's likely that you'll select macOS 64-bit (x86_64). If you have a newer macOS machine, then it's likely you'll have to select macOS 64-bit (arm64, Apple M1 silicon). It's unlikely that any of you are using a 32-bit macOS operating system. If you're not sure which macOS system you have, then let me know and I can help you determine the appropriate platform. Alternatively, follow these instructions to find your processor information:
- click on the Apple menu
- choose About This Mac
- locate the Processor or Chip information
After you have downloaded the gcloud CLI for your particular OS and CPU architecture, you will need to open a command prompt/terminal on your machines to complete the instructions that describe how to install the gcloud CLI. macOS uses the Terminal app, which can located using Spotlight. Windows user can use Command.exe, which can be located by search also.
Windows users will download a regular .exe file,
but macOS users will download a .tar.gz file.
Since macOS is Unix, you can use the mv
command to
move that file to your $HOME
directory.
Then you extract it there using the tar
command,
and once extracted
you can change to the directory that it
creates with the cd
command.
For example, if you are downloading the X86_64 version
of the gcloud CLI, then you would run the following commands:
For macOS users, this assumes the .tar.gz file was downloaded to your default Downloads folder:
cd ~/Downloads/
mv google-cloud-cli-392.0.0-darwin-x86_64.tar.gz ~/
cd ~/
tar -xzf google-cloud-cli-392.0.0-darwin-x86_64.tar.gz
cd google-cloud-sdk
Modify the above commands, as appropriate, if you're using the M1 or the M2 version of the gcloud CLI.
Initializing the gcloud CLI
As above, please follow the instructions from the Google Cloud documentation for your operating system.
Once you have downloaded and installed the gcloud CLI program, you need to initialize it on your local machine. Scroll down on the install page to the section titled Initializing the gcloud CLI. In your terminal/command prompt, run the initialization command, per the instructions at the above page:
gcloud init
And continue to follow the instructions from the prompt and from the Google Cloud documentation page above.
gcloud VM Instance
Once you've initialized gcloud, log into Google Cloud Console, which should take you to the Dashboard page.
Our first goal is to create a virtual machine (VM) instance. As a reminder, a VM is basically a virtualized operating system. That means instead of installing an operating system (like Linux, macOS, Windows, etc) on a physical machine, software is used to mimic the process.
gcloud offers a number of Linux-based operating systems to create VMs. We're going to use the Ubuntu operating system and specifically the Ubuntu 20.04 LTS version.
Ubuntu is a Linux distribution. There are many, many distributions of Linux, and most are probably listed on the DistroWatch site. A new version of Ubuntu is released every six months. The 20.04 signifies that this is the April 2020 version. LTS signifies Long Term Support. LTS versions are released every two years, and Canonical LTD, the owners of Ubuntu, provide standard support for LTS versions for five years.
LTS versions of Ubuntu are stable. Non-LTS versions of Ubuntu receive nine months of standard support, and generally apply cutting edge technology, which is not always desirable for server operating systems. Each version of Ubuntu has a code name. 20.04 has the code name Focal Fossa. You can see a list of versions, code names, release dates, and more on Ubuntu's Releases page.
We will create our VM using the gcloud console. To do so, follow these steps from the Project page:
- Click on the hamburger icon (three vertical bars) in the top left corner.
- Click on Compute Engine and then VM instances
- Make sure your project is listed.
- Next, click on Create Instance.
- Provide a name for your instance.
- E.g., I chose main-ubuntu (no spaces)
- In the Machine configuration section, make sure E2 is selected.
- In the Machine type section, select e2-micro (2 vCPU, 1 core, 1 GB memory)
- This is the lowest cost virtual machine and perfect for our needs.
- Under Boot disk, click on the Change button.
- In the window, select Ubuntu from the Operating system drop down box.
- Select Ubuntu 20.04 LTS x86/64
- Leave Boot disk type be set to Balanced persistent disk
- Disk size should be set to 10 GB.
- Click on the Select button.
- Check the Allow HTTP Traffic button
- Finally, click on the Create button to create your VM instance.
Later in the semester when we install Koha, we will need to create a virtual machine with more CPUs and memory. We will be charged more for those machines. Since we do not yet need the extra resources, we will start off with fairly low powered machines.
Connect to our VM
After the new VM machine has been created, we need to connect to it via the command line. macOS users will connect to it via their Terminal.app. Windows users can connect to it via their command prompt.
We use a ssh
command
to connect to our VMs.
The syntax follows this pattern:
gcloud compute ssh --zone "zone-info" "name-info" --project "project-id"
The values in the double quotes in the above command can be located in your Google Cloud console and in your VM instances section. See the course video for details.
Update our Ubuntu VM
The VM will include a recently updated version of Ubuntu 20.04, but it may not be completely updated. Thus the first thing we need to do is update our machines. On Ubuntu, we'll use the following two commands, which you should run also:
sudo apt update
sudo apt -y upgrade
Then type exit
to logout and quit the connection to the remote server.
exit
When you log into your machines, you'll note a command prompt that ends with a dollar sign
$
. This is where we type our commands. The command prompt also displays our location in the file system. The tilde~
is a shorthand symbol for our home directory. By default, we are placed in our home directory whenever we login to our machines.
Snapshots
Lastly, we have installed a pristine version of Ubuntu, but it's likely that we will mess something up as we work on our systems. Or it could be that our systems may become compromised at some point. Therefore, we want to create a snapshot of our newly installed Ubuntu server. This will allow us to restore our server if something goes wrong later.
To get started:
-
In the left hand navigation panel, click on Snapshots.
-
At the top of the page, click on Create Snapshot.
-
Provide a name for your snapshot: e.g., ubuntu-1.
-
Provide a description of your snapshot: e.g.,
This is a new install of Ubuntu 20.04.
-
Choose your Source disk.
-
Choose a Location to store your snapshot.
- To avoid extra charges, choose Regional.
- From the drop down box, select the same location (zone-info) your VM has
-
Click on Create
Please monitor your billing for this to avoid costs
that you do not want to incur.
Conclusion
Congratulations! You have just completed your first installation of a Linux server.
To summarize, in this section, you learned about and created a VM with gcloud. This is a lot! After this course is completed, you will be able to fire up a virtual machine on short notice and deploy websites and more.
Learn the Command Line Interface (CLI)
Introduction
There are two major interfaces that we use to interact with our computers. The most common interface is the graphical user interface, or GUI. This interface largely emphasizes non-textual interaction, such as the mouse, fingers (touch screens), remote controls (e.g., smart TVs), and more recently, wearable tech such as VR headsets and like. All of the above mechanisms for interacting with our computer systems are worthwhile, but more importantly, they are all suited to specific ranges of engagement with our computers. That is, they afford certain kinds of actions (Dourish, 2001).
The other major way of interfacing with our computers is via the command line interface, or CLI. The CLI is also suited to specific ranges of engagement, and it's the kind of engagement that allows greater control over the fundamental uses of our systems.
One reason the CLI provides greater control over our systems is because the interaction is text-based. Text-based interaction requires more specificity than graphical-based interaction. By that I mean, it requires us to provide written instructions to a computer and to know what instructions to give it when we want the computer to perform some specific action. This means that we have to memorize some common instructions in order to use our systems. This is not necessarily difficult because many of the most common instructions, or commands, are mnemonic, but it does take some getting used to.
A second reason the CLI provides greater control over the system is that because it's text-based, it can be automated. We will not cover programming in this work or course, but know that all the commands that we will learn can be put in a text file, made into an executable file, and run like a program. This makes text-based interaction rather powerful.
The big gotcha with a text-based interface with the computer is that it requires specificity. We have to be fairly exact in our commands. This exactitude requires an attention to detail. Little things like misplaced punctuation, missing punctuation, incorrect capitalization or indentation, and misspelled words can cause errors or prevent the execution of our programs. It's important to proceed slowly on the command line and to pay attention to the messages the screen displays when we run commands.
Basic Commands
In light of that, I have developed two programs that will help you learn and remember basic Linux shell commands. The commands that I'll ask you to learn encompass less than 0.3% of the commands that are available on a Linux system, but they are the most commonly used commands. Many of the other commands that are available are for very specific purposes. I'd estimate that despite having used the Linux command line for over 20 years, I've barely used 20% of them, and I might be stretching my estimate.
The first set of commands that I'll ask you to learn and practice include the following:
list files and directories.................. ls
print name of current/working directory..... pwd
create a new directory...................... mkdir
remove or delete an empty directory......... rmdir
change directory............................ cd
create an empty file........................ touch
print characters to output.................. echo
display contents of a text file............. cat
copy a file or directory.................... cp
move or rename a file or directory.......... mv
remove or delete a file or directory........ rm
You will practice these commands using the program that I wrote called learn-the-cli (I will show you how to install this and the other programs shortly).
I also developed a flashcards
program that will help you learn,
or at least become familiar,
with an additional 45 commands.
(This program is based on one created
by someone else for a different purpose;
see source code link above for credit).
I'll explain these additional commands
as we proceed through the semester.
In the meantime,
I'll ask that you periodically run
the flashcards
program to
familiarize yourself with these commands,
which includes the ones in the list above
but also a few additional ones.
The Filesystem
In addition to the various commands that I'll ask you to learn, you will also have to learn the structure of the Linux filesystem. A filesystem has several meanings, but in this context, I refer to where the directories on the Linux system are placed. I find this to be the most difficult thing that new Linux users have to learn for a couple of reasons. First, modern operating systems tend to hide (abstract away) the filesystem from their users. So even though, for example, macOS is Unix, many macOS users that I have taught are completely unfamiliar with the layout of directories on their system. This is because, per my observations, macOS Finder does not show the filesytem by default these days. Instead it shows its users some common locations for folders. This might make macOS more usable to most users, but it makes learning the system more difficult.
What's common for both macOS and Linux
operating systems is a filesytem based on a
tree-like structure.
These filesystems begin at what's called a
root location.
The root location is referenced by
a forward slash: /
.
All directories branch off from root.
The location to any directory is called
a PATH.
For example, our home directories on
Linux are located at the following PATH:
/home/USER
That PATH begins at the root directory /
,
proceeds to the directory named home
, and
then ends in our USER directory,
which will share the same name as our usernames.
As an example,
if my username on a Linux system is sb,
then my home directory will be located at:
/home/sb
It is a little different for Windows users. Since Windows is not Unix-like, it uses a different filesystem hierarchy. Many Windows users might be familiar with the basics, such as the C: drive for the main storage device or the D: drive for an added USB stick. As such, the Windows operating system uses multiple root directories (C:, D:, E:, etc.). I encourage you to read the following article on A quick introduction to the Linux filesystem for Windows users. The article is published by Red Hat, which makes its own Linux distribution.
In short, learning the Linux filesystem requires adopting a new mental model about how the operating system organizes its directories and files. Like learning the basic commands, it's not too hard, but it may take time and practice before it sticks. To help learn it, I wrote an additional program that will let you practice navigating around the Linux filesystem and making some changes to it. The program is called learn-the-filesystem. Before you use this program, I would like to encourage you to read another Red Hat article on Navigating your filesystem in the Linux terminal. It includes sections that my program will cover that include:
- viewing file lists
- opening a folder (aka, a directory)
- closing a folder
- navigating directories
- absolute paths
Bash: The Bourne Again Shell
I should point out that the
command line interface that we
are using on our Linux servers
is provided by a shell.
A shell is "both an interactive
command language and a scripting
language" (see link above).
We will use the shell strictly
as a command language,
but if you're interested someday,
I'd encourage you to explore Bash
as a scripting language
(I personally script in Bash quite a lot, and the
learn-the-cli and flashcard programs
were written in bash
).
There are a variety of shells
available for Linux and other Unix-like
operating systems, but
the most popular one and
the one we will be using is called
Bash.
Bash is an acronym for the Bourne Again Shell because it's based on the original Unix shell called the Bourne shell, written by Stephen Bourne. Bash itself was written by Brian Fox.
I think it's important to know the history of the technologies that we use, and Bash has a super interesting history that pre-exists Linux. Therefore, I highly encourage you listen to the Command Line Heroes episode titled Heroes in a Bash Shell, narrated by Saron Yitbarek. The episode recounts Brian Fox's history with the Bash shell while he worked for the Free Software Foundation in the 1980s.
Conclusion
We will spend the next few weeks practicing these commands and learning the filesystem. We'll do this because knowing these things is integral to accomplishing everything else in this work, including installing and setting up our content management systems and the integrated library system.
In the video for this week,
I'll show you how to install the three
programs that I wrote or modified.
We will use git
to download them.
The we will move the programs to a
specific directory in our
executable PATH.
This will allow us to run them
simply by typing their names.
Installation
To install my practice programs, login to your Linux virtual instances, and run the following commands. You will learn more about these commands shortly.
First, let's take a look at the contents of your home directory (the default directory you're in when you connect to your virtual machine):
ls
Most likely, nothing will be listed.
Now let's retrieve the programs
using the git
command:
git clone https://github.com/cseanburns/learn-the-commandline.git
Run the ls
command again, and
you'll see a new directory called
learn-the-commandline
:
ls
Next, copy the programs to an executable path:
sudo cp learn-the-commandline/* /usr/local/bin
Run the first program and work through it in order to learn some of the basic commands:
learn-the-cli
When ready, run the second program in order to learn about the Linux filesystem:
learn-the-filesystem
Finally, periodically run the
flashcards
program to refresh your
memory of the basic commands, plus
some other commands that you'll learn
about soon:
flashcards
After working through the
learn-the-cli
program a few times,
you can continue
to practice with the
learn-the-cli-module
program.
This is a modified version that
allows you to focus specific
learning modules.
Resources
Here are some additional resources for learning Bash and Linux shell commands:
- explainshell.com : helps explain the parts of a shell command
- shellcheck.net : helps debut a shell script
- The Art of the Command Line : describes the fundamentals of Bash and the command line
References
Dourish, P. (2001). Where the Action Is: The Foundations of Embodied Interaction. MIT Press. https://doi.org/10.7551/mitpress/7221.001.0001
Text editors
As we learn more about
how to work on the command line,
we will acquire the need to write
in plain text or edit
configuration files.
Most configuration files for Linux
applications exist
in the /etc
directory,
and are regular text files.
For example,
later in the semester
we will install the
Apache Web Server, and
we will need to edit
Apache's configuration
files in the process.
In order to edit and save text files, we need a text editor. Programmers use text editors to write programs, but because programmers often work in graphical user environments, they may often use graphical text editors or graphical Integrated Development Environments (IDEs). It might be that if you work in systems librarianship, that you will often use a graphical text editor, but knowing something about how to use command line-based editors can be helpful.
What is a Plain Text?
Plain text is the most basic way to store human-readable textual information. Whenever we use a word processor program, like Microsoft Office, we are creating a complex series of files that instruct the Office application how to display the contents of the file as well as how the contents are formatted and arranged. This can easily be illustrated by using an archive manager to extract the contents of a .docx file. Upon examination, most of the files in a single .docx file are plain text that are marked up in XML. The files are packaged as a .docx file and then rendered by an application, commonly Microsoft Word, but any application that can read .docx files will do.
A plain text file only contains plain text. Its only arrangement is from top to bottom. It does not allow for any kind of additional formatting, and it does not include media. It is the closest thing the digital has to output produced by a typewriter, but a typewriter that's connected to the internet.
A lot of content is written in plain text. For example, HTML is written in plain text and the web browser uses the HTML markup to render how a page will look.
<p>This is using a HTML paragraph tag.
The web browser would normally render this like
the other paragraphs on this page.
However, it's written in a code block,
which allows us to display the HTML tags
and appear as if it's real source code.</p>
The rendered result is not plain text but HTML, just like the rendered result of all those XML files in a .docx file are not plain text but a .docx file. Softare is written in plain text files because programming languages cannot evaluate content that is not just text. Those of you who have learned how to use the R programming language wrote your R code in plain text likely using the RStudio IDE. For our purposes, we need plain text files to modify configuration files for the various programs that we will install later.
Why Edit in Plain Text
Most of the time when we configure software, we might do it, for example, by using our mouse to find the settings menu in some application that we are using. All that does, for the most part, is make changes to some text file somewhere. We will have to be more direct since we are working on the command line only. That is, the kind of settings configurations we will do will require editing a variety of plain text files that the programs will use to modify how they work. Often the settings for programs can only be modified by editing their plain text configuration files.
nano
The nano
text editor
is a fairly user-friendly
command line text editor, but
it requires some learning
as a new command line user.
The friendliest thing about
nano
is that it is modeless,
which is what you're
already accustomed to using.
This means nano
can be used
to enter and manipulate text
without changing to
insert or command mode.
It is also friendly because,
like many graphical text editors
and software,
it uses control keys
to perform its operations.
A modal text editor has modes such as insert mode or command mode. In insert mode, the user types text as anyone would in any kind of editor or word processor. The user switches to command mode to perform operations on the text, such as find and replace, saving, cutting and pasting but cannot insert text as they would in insert mode. Switching between modes usually involves pressing some specific keys. In Vim and ed(1), my text editors of choice, the user starts in command mode and switches to insert mode by pressing the letter i or the letter a. The user may switch back to command mode by pressing the Esc key in Vim or by pressing the period in a new line in ed(1).
The tricky part to learning nano
is that
the control keys are assigned
to different keystroke combinations
than what
many graphical editors
(or word processors) use
by convention today.
For example,
instead of Ctrl-c or Cmd-c to copy text,
in nano
you press the M-6
key
(press Alt, Cmd, or Esc key
and 6
) to copy.
Then to paste,
you press Ctrl-u
instead
of the more common Ctrl-v
.
Fortunately, nano
lists
the shortcuts at the bottom
of the screen.
nano
is a text-editor with old origins. Specifically, it's a fork of the Unixpico
editor. The keyboard shortcuts used bynano
were carried over from thepico
editor. These keyboard shortcuts were designed before the Common User Access guidelines helped standardize the common keyboard shortcuts we use today for opening, saving, closing, etc files.
The shortcuts listed
need some explanation, though.
The carat mark is shorthand
for the keyboard's Control (Ctrl) key.
Therefore to Save As a file,
we write out the file
by pressing Ctrl-o
(although Ctrl-s
will work, too).
The M- key is also important,
and depending on your keyboard
configuration,
it may correspond to your
Alt, Cmd, or Esc
keys.
To search for text,
you press ^W
,
If your goal is to copy,
then press M-6
to copy a line.
Move to where you want
to paste the text,
and press Ctrl-u
to paste.
We can start nano
simply
by typing nano
on the command line.
This will open a new, unsaved file
with no content.
Alternatively, we can start nano
by specifying a file name after typing nano
.
For example, if I want to open a file
called example.txt,
then I type the following command:
nano example.txt
If the file doesn't exist, this will create it. If it does exit, then the above command will open it.
One of the other tricky things about nano
is that the menu bar
(really just a crib sheet, so to speak)
is at the bottom of
the screen instead of at the top,
which is where we are mostly accustomed to
finding it these days.
Also, the nano
program does not provide
pop up dialog boxes.
Instead, all messages from nano
,
like what to name a file when we save it,
appear at the bottom of the screen.
Lastly, nano
also uses distinct terminology
for some of its functions.
The most important function to remember
is the Write Out function,
which means to save.
For the purposes of this class,
that's all you really
need to know about nano
.
Use it and get comfortable writing in it.
Some quick tips:
nano file.txt
will open and display the file named file.txt.nano
by itself will open to an empty page.- Save a file by pressing
Ctrl-o
. - Quit and save by pressing
Ctrl-x
. - Be sure to follow the prompts at the bottom of the screen.
Other Editors
It's important to be familiar with
nano
because it's generally the default
text editor on Linux operating systems nowadays.
However, if you are interested in using a
command line text editor with familiar keyboard shortcuts,
then there are others you may want to try.
In the meantime,
here are a couple of more friendly editors
to test out.
tilde
The tilde
text editor is a user friendly
text editor that uses conventional keybindings
(like ctrl-s for saving, etc).
You can install it via the apt
command:
sudo apt install tilde
micro
The micro
text editor is also user friendly,
and, like tilde
, uses conventional key bindings.
Press ctrl-g to enter its help menu.
Use your arrow keys to read through it and
learn more about its capabilities and its functions.
Press ctrl-q to exit the help menu.
You can install it via the apt
command:
sudo apt install micro
ed(1), Vi/Vim, Emacs
ed(1), Vi/Vim, and Emacs are
the traditional Unix and Linux text editors.
I first started using Linux
because I found emacs
,
but sometime during my early
Linux years,
I switched to vim
,
which is a descendent of the
vi
text editor,
which itself is a descendent
of the ed
editor.
None of these editors are
user-friendly, but
they are extremely powerful
once you learn them, and
they are still quite popular
(well, ed
probably isn't
all that popular).
There are plenty of online
resources that provide
tutorials on getting started with
these text editors.
I won't teach how to use them
because it will take too much time,
but they are worth knowing about
because all three are important
parts of Unix and Linux history.
Conclusion
In the prior lesson,
we learned how to use the
Bash interactive shell.
We will continue to do that,
but in the meantime,
in this lesson,
we begin to learn how to use
a command line text editor, nano
.
I also introduce you to friendlier
editors (tilde
and micro
)
that you might prefer over nano
.
We will use a text editor to edit
configuration files and publish
text to GitHub.
It's your choice what
you want to use.
My .nanorc
You can configure nano
to look and behave in certain ways.
If you want to mimic
the setup I have,
then create a file called
.nanorc in your home directory,
and add the following to it:
# set element fgcolor,bgcolor
set titlecolor brightwhite,blue
set statuscolor brightwhite,green
# set errorcolor brightwhite,red
set selectedcolor brightwhite,magenta
# set stripecolor ,yellow
set numbercolor cyan
set keycolor cyan
set functioncolor green
set speller "aspell -x -c"
## When soft line wrapping is enabled, make it wrap lines at blanks
## (tabs and spaces) instead of always at the edge of the screen.
set atblanks
## Use auto-indentation.
set autoindent
## Back up files to the current filename plus a tilde.
# set backup
## The directory to put unique backup files in.
# set backupdir "~/.backup"
## Use bold text instead of reverse video text.
set boldtext
## Remember the used search/replace strings for the next session.
set historylog
## Display line numbers to the left of the text.
set linenumbers
## Enable vim-style lock-files. This is just to let a vim user know you
## are editing a file [s]he is trying to edit and vice versa. There are
## no plans to implement vim-style undo state in these files.
set locking
## Remember the cursor position in each file for the next editing session.
set positionlog
## Do extended regular expression searches by default.
set regexp
## Allow nano to be suspended.
set suspend
## Use this tab size instead of the default; it must be greater than 0.
set tabsize 8
## Convert typed tabs to spaces.
set tabstospaces
Documentating with Git, GitHub, and Markdown
Learning the Command Line
It's obviously more common for people today to learn how to use a computer via a graphical user interface (GUI), but there are benefits to learning a command line interface (CLI). In this section, we learn some of the basics of using the Bash shell as our CLI. Our primary goal is to learn how to use the CLI as a file manager and to perform some text editing. However, if you find this interface appealing, know that Bash is a full-fledged programming language, and I encourage you to explore it as a scripting language.
There are three reasons, from a systems administration/librarianship point of view, to prefer the CLI over the GUI.
- First, the GUI entails extra software, and the more software we have on a server, the more resources (memory, CPU, storage, etc) that software consumes. We would much rather have our machine's resources being used to provide the services we build them to do than to run irrelevant software.
- Second, the extra software a GUI requires means that we expose our systems to additional security risks. That is, every time we install more software on our servers, the server becomes more vulnerable because all software is buggy. This means that we want to be conservative, careful, and protective of our systems. This is especially true for production systems.
- Third, graphical user interfaces do not provide a good platform for automation, at least not remotely as well as command line interfaces do. Working on the command line, because it is a text-based environment, in what is known as a shell, is a reproducible process. That is not as easily true in a GUI.
Fortunately, Linux, and many other Unix-like operating systems, have the ability to operate without graphical user interfaces. This is partly the reason why these operating systems have done so well in the server market.
In this section, our focus is learning the command line environment. We will do this using the Bash shell. We will learn how to use the shell, how to navigate around the filesystem, how to perform basic tasks, and explore other functions and utilities the shell has to offer.
Searching with grep
We have available some powerful utilities and programs
to process, manipulate, and analyze text files.
In this section, we will focus on the grep
utility,
which offers some advanced methods for searching
the contents of text files.
Grep
The grep
command is one of my most often used commands.
The purpose of grep
is to "print lines that match patterns"
(see man grep
).
In other words, it searches text, and
it's super powerful.
grep
works line by line.
So when we use it to search a file for a string of text,
it will return the whole line that matches the string.
This line by line idea is part of the history of
Unix-like operating systems,
and it's important to remember that most utilities
and programs that we use on the commandline
are line oriented.
"A string is any series of characters that are interpreted literally by a script. For example, 'hello world' and 'LKJH019283' are both examples of strings." -- Computer Hope. More generally, it's a type of data structure.
To visualize how grep
works,
let's consider a file called
operating-systems.csv with content
as seen below:
OS, License, Year
Chrome OS, Proprietary, 2009
FreeBSD, BSD, 1993
Linux, GPL, 1991
macOS, Proprietary, 2001
Windows NT, Proprietary, 1993
Android, Apache, 2008
We can use grep
to search
for anything in that file.
Let's start with a search for the string Chrome.
Notice that even though the string Chrome only appears once,
and in one part of a line,
grep
returns the entire line.
Command:
grep "Chrome" operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
Case Matching
Be aware that, by default, grep
is case-sensitive,
which means a search for the string chrome,
with a lower case c,
would return no results.
However, many Linux command line utilities
can have their functionality extended
through command line options.
grep
has an -i
option
that can be used to
to ignore the case of the search string.
In the following examples,
grep
returns nothing in the first search
since we do not capitalize the string chrome.
However, adding the -i
option results in success
since grep
is instructed to ignore case:
Command:
grep "chrome" operating-systems.csv
Output:
None.
Command:
grep -i "chrome" operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
Invert Matching
grep
can do inverse searching.
That is, we can search for lines
that do not match our string
using the -v
option.
Options can often be combined
for additional functionality.
We can combine -v
to inverse search
with -i
to ignore the case.
In the following example,
we search for
all lines that
do not contain the
string chrome:
Command:
grep -vi "chrome" operating-systems.csv
Output:
FreeBSD, BSD, 1993
Linux, GPL, 1991
iOS, Proprietary, 2007
macOS, Proprietary, 2001
Windows NT, Proprietary, 1993
Android, Apache, 2008
Regular Expressions
Sometimes data files,
like spreadsheets,
contain header columns in the
first row.
We can use grep
to remove
the first line of a file by
inverting our search and
selecting all lines not matching
"OS" at the start of a line.
Here the carat key ^
is
a regex indicating the
start of a line.
Again, this grep
command returns
all lines that do not match the
string os at the start of a line,
ignoring case:
Command:
grep -vi "^os" operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
FreeBSD, BSD, 1993
Linux, GPL, 1991
iOS, Proprietary, 2007
macOS, Proprietary, 2001
Windows NT, Proprietary, 1993
Android, Apache, 2008
Alternatively, since we know that
the string Year comes
at the end of the first line,
we can use grep
to invert search for that.
Here the dollar sign key $
is a regex indicating the
end of a line.
Like the above,
this grep
command returns all lines that
do not match the string year
at the end of a line,
ignoring case.
The result,
in this specific instance,
is exactly the same as the last command:
Command:
grep -vi "year$" operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
FreeBSD, BSD, 1993
Linux, GPL, 1991
iOS, Proprietary, 2007
macOS, Proprietary, 2001
Windows NT, Proprietary, 1993
Android, Apache, 2008
The man grep
page lists other options,
but a couple of other good ones include:
Count Matches
Get a count of the matching lines
with the -c
option.
For example,
let's get a total count of rows
in our file excluding the header
by adding the -c
option:
grep -vic "year$" operating-systems.csv
Alternate Matching
We separate the strings with a vertical bar |
(the infix operator)
to match any string on either side.
This is similar to a Boolean OR search.
Since there's at least one match in the following string,
there is at least one result.
Here is an example where only one string returns a true value since the file contains bsd but not atari:
Command:
grep -Ei "(bsd|atari)" operating-systems.csv
Output:
FreeBSD, BSD, 1993
Here's an example where both strings evaluate to true:
Command:
grep -Ei "(bsd|gpl)" operating-systems.csv
Output:
FreeBSD, BSD, 1993
Linux, GPL, 1991
Whole Word Matching
By default, grep
will return results where the
string appears within a larger word,
like OS in macOS.
Command:
grep -i "os" operating-systems.csv
Output:
OS, License, Year
Chrome OS, Proprietary, 2009
iOS, Proprietary, 2007
macOS, Proprietary, 2001
However, we might want to limit results so that we only return results where OS is a complete word. To do that, we can surround the string with special characters:
Command:
grep -i "\<os\>" operating-systems.csv
Output:
OS, License, Year
Chrome OS, Proprietary, 2009
Sometimes I find it hard to remember
the backslash and angle bracket combinations
because they're too much alike HTML syntax but
not exactly like HTML syntax.
Fortunately, grep
has a -w
option
to match whole words:
Command:
grep -wi "os" operating-systems.csv
Output:
OS, License, Year
Chrome OS, Proprietary, 2009
Context Matches
Sometimes we want the context for a result;
that is,
we might want to print lines
that surround our matches.
For example,
to print the matching line plus the two lines
after the matching line using the -A NUM
option,
where NUM equals the number of lines
to return after the matching line:
Command:
grep -i "linux" -A2 operating-systems.csv
Output:
Linux, GPL, 1991
macOS, Proprietary, 2001
Windows NT, Proprietary, 1993
Or, print the matching line plus the two lines
before the matching line using the -B NUM
option:
Command
grep -i "linux" -B2 operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
FreeBSD, BSD, 1993
Linux, GPL, 1991
We can combine many of the variations. Here I search for the whole word BSD, case insensitive, and print the line before and the line after the match:
Command:
grep -iw -C1 "bsd" operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
FreeBSD, BSD, 1993
Linux, GPL, 1991
Halt Matching
We can use another option to
stop returning results after some
number of hits.
Here I use grep
to return
a search for the string "proprietary"
and stop after the first hit:
Command:
grep -i -m1 "proprietary" operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
Returning Line Numbers
We can add the -n
option to
instruct grep
to tell us the
line number for each hit.
Below we see that the string
"proprietary" is found on lines
2, 5, and 6.
Command:
grep -in "proprietary" operating-systems.csv
Output:
2:Chrome OS, Proprietary, 2009
5:macOS, Proprietary, 2001
6:Windows NT, Proprietary, 1993
Character Class Matching
We can use grep
to search for
patterns in strings instead of literal words.
Here we use what's called character classes
and repetition to search for five letter words
that contain any English character a through z:
Command:
grep -Eiw "[a-z]{5}" operating-systems.csv
Output:
Linux, GPL, 1991
macOS, Proprietary, 2001
Or four letter numbers, which highlights the years:
Command:
grep -Eiw "[0-9]{4}" operating-systems.csv
Output:
Chrome OS, Proprietary, 2009
FreeBSD, BSD, 1993
Linux, GPL, 1991
macOS, Proprietary, 2001
Windows NT, Proprietary, 1993
Android, Apache, 2008
grep
can also search for words that
begin with some letter and end with some letter
and with a specified number of letters between.
Here we search for words that start with m,
end with s, and have three letters in the middle:
Command:
grep -Eiw "m.{3}s" operating-systems.csv
Output:
macOS, Proprietary, 2001
Practice
Let's use the grep
command
to investigate bibliographic data.
Our task is to:
- Search Scopus.
- Download a BibTeX file from Scopus as a .bib file.
- Use the
grep
command to search the downloaded BibTeX file, which should be named scopus.bib.
Download Data
I'm using Scopus data in this example, but other bibliographic data can be downloaded from other databases.
- From your university's website, find Scopus.
- In Scopus, perform a search.
- Select the documents you want to download.
- Click on the Export button.
- Click on BibTeX under the listed file types.
- Select all Citation Information and Bibliographic Information. Select more in interested.
- Click on Export.
The file should be saved to your Downloads folder and titled scopus.bib.
Upload to gcloud
To upload to gcloud
,
you use a similar command
as the gcloud compute ssh
command that you use
to connect to your servers.
However, there are some differences.
The gcloud
copy command uses
scp
instead of ssh
and
then specifies the local file to transfer
and the remote location.
The following command
copies the local file
titled file_name
to the remote server.
Simply replace the file name,
server, zone, and project names
with those specific
to your virtual instances.
gcloud compute scp file_name "server_name":~/ --zone "zone_name" --project "project_name"
There are other ways to transfer files to the virtual instance from your local computer, but they raise some complications. If interested, see Transfer files to Linux VMs.
Investigate
Now that the file is uploaded, the first task is to to get an understanding of the structure of the data. BibTeX (.bib) files are structured files that contain bibliographic data. It's important to understand how files are structured if we want to search them efficiently.
The scopus.bib file begins with information about the source (Scopus) of the records and the date the records were exported. These two lines and the empty line after them can be safely deleted or ignored.
Each bibliographic record in the file begins with an entry type (or document type) preceded by an at @ sign. Example entry types include: article, book, booklet, conference, and more. There is a opening curly brace after the entry or document type. These curly braces mark the beginning and ending of each record.
The cite key follows the opening curly brace. The cite key is an identifier that often refers to the author's name and includes publication date information. For example, a cite key might look as follows and would stand for the author Budd and the date 2020-11-23.
Budd20201123
The rows below the entry type contain the metadata for the record. Each row begins with a tag or field name followed by an equal sign, which is then followed by the values or content for that tag. For example, there's an author tag, an equal sign, and then a list of authors. There is a standard list of BibTeX fields. Example fields include: author, doi, publisher, title, journal, year, and more. The fields are standardized because some programs use BibTeX records to manage and generate bibliographies, in-text citations, footnotes, etc..
The content of each field is enclosed in additional curly braces. Each line ends with a comma, except for the last line. The record ends with a closing curly brace.
Document Types
We can use grep
to
examine the types of documents
the records point to.
In the following command,
I use the carat key ^,
which is a regular expression
to signify the start of a line,
to search for lines beginning
with the at @ symbol.
The following grep
command
therefore means:
return all lines that begin
with the at @ symbol:
grep "^@" scopus.bib
The results show, for this particular data, that I have BOOK and ARTICLE entry types. The data I'm using does not contain many records, but if it contained thousands or more, then it would be helpful to filter these results.
Thus, below I use the -E option
to extend grep
's regular expression engine.
I use the (A|B) to tell grep
to search
for letters after the at sign @
that start with either A or B,
for ARTICLE or BOOK.
Then I use regular expression
character class matching
with [A-Z]* to match any letters
after the initial A or B characters.
The -i option turns off case sensitivity,
and the -o option returns
only matching results from the lines.
I pipe the output of the grep
command
to the sort
command to sort the
results alphabetically:
grep -Eio "^@(A|B)[A-Z]*" scopus.bib | sort
Tip: Without using the
sort
command, thegrep
command returns the results in the order it finds them. To see this, run the above command with and without piping to thesort
command to examine how the output changes.
Now let's get a frequency of the document types.
Here I pipe |
the output from the grep
command to the sort
command,
in order to sort the output alphabetically.
Then I pipe the output from the sort
command to the uniq
command.
The uniq
command will deduplicate
the results, and
the -c option will count the
number of duplicates.
As a result,
it will provide an overall
count of the document or entry types
we searched.
grep -Eio "^@(A|B)[A-Z]*" scopus.bib | sort | uniq -c
Journal Titles
We can parse the data for other information. For example, we can get a list of journal titles by querying for the journal tag:
grep "journal" scopus.bib
Even though that works,
the data contains
the word Journal
in the name of some journals.
If we were searching thousands
or more records,
we might want to construct a more
unique grep
search.
To rectify this,
we can modify our grep
search
in two ways.
First, the rows of data fields
begin with a tab character.
The regular expression
for the tab character is \t.
Therefore, we can search
the file using this expression
with the -P option:
grep -P "\tjournal" scopus.bib
Second, we can simply add more
unique terms to our grep
search.
Since each tag includes a space,
an equal sign,
followed by another space,
we can use that in our grep
query:
grep "journal =" scopus.bib
Using either method above,
we can extract the journal title information.
Here I use two new commands,
cut
and sed
.
The cut
command takes
the results of the grep
command,
removes the first column based on
the comma as the column delimiter.
In the first sed
command,
I remove the space and opening
curly brace and replace it with nothing.
In the second sed
command,
I remove the closing curly brace and
the comma and replace it with nothing.
The result is list of only the journal titles
without any extraneous characters.
I then pipe the output to the sort
command,
which sorts the list alphabetically,
to the uniq -c
command,
which deduplicates and counts the results,
and again to the sort
command,
which sorts numerically,
since the first character is a number:
grep "journal =" scopus.bib | cut -d"=" -f2 | \
sed 's/ {//' | sed 's/},//' | \
sort | uniq -c | sort
Total Citations
There are other things we can
do if we want to learn more powerful technologies.
While I will not cover awk
,
I do want to introduce it to you.
With the awk
command,
based on the BibTeX tag that
includes citation counts
at the time of the download
(e.g., note = {Cited by: 2}),
we can extract the number from
that field for each record and
sum the total citations for
the records in the file:
grep -o "Cited by: [0-9]*" scopus.bib | \
awk -F":" \
'BEGIN { printf "Total Citations: "} \
{ sum += $2; } \
END { print sum }'
In the above command, we use the pipe operator to connect a series of commands to each other:
- use
grep
to search for the string "Cited by: " and to include any number of digits - use
awk
to use the colon as the column or field delimiter - use the
awk
BEGIN statement to print the words "Total Citations: " - instruct
awk
to sum the second column, which is the citation numbers - use the
awk
END statement to print the sum.
If you want to learn more about
sed
andawk
, please see my text processing chapter for my Linux Systems Administration. There are also many tutorials on the web.
Conclusion
grep
is very powerful, and
there are more options listed in its man
page.
The Linux (and other Unix-like OSes) command line
offers a lot of utilities to examine data.
It's fun to learn and practice these.
Despite this, you do not have to become
an advanced grep
user.
For most cases,
simple grep
searches work well.
There are many grep
tutorials on the web
if you want to see other examples.
Managing Software
Introduction
Most Linux distributions use
what's called a package manager to
handle the installation, upgrades, and
uninstalls of the software on a system.
The Ubuntu distribution uses a
package manager called dpkg
and
a front-end called apt
(advanced package tool).
We will use apt
to install,
update, and remove software
from our servers.
sudo
In order to use the package manager,
we will need
the sudo
command.
The sudo
command allows us to
"execute a command as another user"
(see man sudo
).
By default,
the sudo
command
"executes a command as the superuser"
(see man 8 sudo
).
The name of the superuser account
is root.
This user can perform administrative tasks
that regular users cannot.
For security purposes,
regular accounts may not add, remove, or
update software on a system, nor
may they modify most files or directories
outside their home directories.
Using sudo
allows regular users to
perform maintenance tasks on our systems
by executing commands as the root user.
Some consider this safer than logging
in as the root user.
Not all regular users can use
the sudo
command.
On regular Ubuntu distributions,
users must belong to the sudo group
in order to run the sudo
command.
The groups
command will return
a list of groups that your account belongs to.
On the Ubuntu version used by the
Google Cloud Platform (GCP),
the group of interest is called google-sudoers.
The difference between the sudo group
on regular Ubuntu distributions and
the GCP version is that regular users in the
google-sudoers group are not prompted for
their password.
Down the line,
we will need to use the sudo
command
to modify files, create directories, and
perform other maintenance tasks needed to
install and manage software.
In this lesson, we will use sudo
along
with the apt
commands to update our
systems and install software.
sudo
syntax
The sudo
command is simple to use.
When necessary,
we use sudo
by pre-pending it to
the regular commands that we have already
learned.
In our home directories, for example,
we don't need to use sudo
to
create a new directory with the mkdir
command.
Instead we type
mkdir data
to create a new
directory/folder called data.
But outside our home directory,
for example, in the directory
/usr/local/bin,
we need to use sudo
to do such things.
(This is why I used the sudo
command
when I showed you how to copy the
Learn the Commandline programs to
/usr/local/bin.)
If I want to create a data directory
in /usr/local/bin, then
I have to use sudo at the beginning of
my command:
cd /usr/local/bin
sudo mkdir data
Or, without changing to that directory, I can just specify the full path:
sudo mkdir /usr/local/bin/data
Or if I want to create a file in some other directory outside my home directory, then I have to use sudo there, too:
cd /srv
sudo touch data.csv
Or, without changing to that directory, I can specify the full path:
sudo touch /srv/data.csv
apt
We will use sudo
in the above
ways soon enough, but for now,
we will use sudo
to install,
update, and uninstall software on
our systems.
Next I'll demonstrate the apt
commands that we'll need.
sudo apt update
Your system keeps a record of
what software is installed on your
system and their version numbers.
The sudo apt update
command
updates that list and compares
the update to what's installed.
That is, if you have a piece of
software called acme1.1 on your system,
and acme1.2 is available, then
running sudo apt update
will
let you know that you can upgrade to
acme1.2.
It's good practice to run sudo apt update
before installing or upgrading your system
because this lets your system upgrade to
the most recent version of what you want
to install.
In short, the command to download new package information is:
sudo apt update
sudo apt upgrade
Once the list of packages have been updated,
you can upgrade with the sudo apt upgrade
command if there are any upgrades.
When you run this command, and if
there are any upgrades,
you will be prompted to proceed.
You can press Y to proceed, or
N to cancel.
This command is simply:
sudo apt upgrade
apt search
If you want to install a piece
of software, then
you have to install it using its
package name.
Sometimes that means we have to
search for the name of the package.
This is one of the apt
commands
that does not require the use of sudo
.
sudo
is not required because
apt search
does not modify the system.
It simply helps you search for a package name.
For example, the man
pages provide
helpful documentation about how to use
the commands on our systems, but
the man
pages can also be dense and
not straightforward.
Fortunately, there's an application called
tldr
that is a community-driven application
that provides simple help pages and examples
of how to use some of the most commonly used
commands.
To search for the tldr
package,
we execute the following command:
apt search tldr
This returns a list of results that
match the search query.
One of those results is the tldr
package,
which is simply named tldr.
Not all packages are simply named,
which is why we need to search for the
specific name.
Note that sometimes when we search for a package, the list of results is quite long. In those cases, pipe the above command through the
less
pager to page through the results:apt search <packagename> | less
apt show
If we want more specific information
about the package,
we can use the apt show
command
along with the package name.
Therefore, to get more information
about the tldr
application,
we execute the following command:
apt show tldr
This will return a fuller description
of the package (usually), as well
as the URL to the application's website,
plus other details.
We do not need to use sudo
here
because we are not modifying the system.
We are only retrieving information.
sudo apt install
To install the tldr
application,
we use the sudo apt install
command
along with the package name.
We want to make sure that the name of the
package is exactly what was returned from
the apt search
command.
In the tldr
case,
it's pretty straightforward, and to install:
sudo apt install tldr
sudo apt remove
In order to remove a package,
we use the sudo apt remove
command.
I like to add the --purge
option
because this also removes system configuration
files that I probably do not need.
That is, some applications
install configuration files (configs)
in the /etc directory.
Adding --purge
will remove those configs.
To remove a package and its system configuration files (if any), we run the above command with the package name.
sudo apt --purge remove tldr
Some configs are stored in your home directory.
Generally only end user applications install
configs in our home directories.
The --purge
option will not remove those configs;
instead, we have to remove them manually if we want.
sudo apt autoremove
One of the great things about dpkg
and apt
is that it installs and handles software
dependencies really well.
Dependencies are other software that software
depends upon to run.
That is, few computer applications are self-contained, and
they often require other software to operate.
When we uninstall (or remove) applications,
the package manager does not auto uninstall those
dependencies that were installed with it.
We use the autoremove command to uninstall those,
which helps keep our systems clean:
sudo apt autoremove
sudo apt clean
When we install packages,
some files are installed with them.
The sudo apt clean
removes those
extra files and frees up disk space.
It's a simple command:
sudo apt clean
Conclusion
The apt
command makes it quite easy
to manage software on our systems.
We will use this command to install more
complicated software later.
Here's a list of commands we covered:
sudo apt update
sudo apt upgrade
apt search
apt show
sudo apt install
sudo apt --purge remove
sudo apt autoremove
sudo apt clean
Library Search
We're going to explore the yaz-client
,
a tool that serves
as a gateway to
information retrieval
using the Z39.50 protocol.
For those unfamiliar,
Z39.50 is a standard protocol
in libraries for
sharing, querying, and retrieving bibliographic information
between library databases.
Development and usage
began in the 1970s,
which of course pre-dates the web,
and this is a testament to the evolution of
information retrieval systems since the 1970s.
The protocol is maintained by the
Library of Congress.
SRU (Search/Retrieve via URL) and
SRW (Search/Retrieve Web service)
are modern web-based successors to Z39.50.
They offer more flexibility
in accessing and sharing bibliographic records.
The yaz-client
allows us to interact
with these protocols
directly from the command line,
which provides a hands-on experience
with the underlying mechanics of
digital library searches and data retrieval.
This exploration is not only about learning a tool; it's about understanding the history and ongoing development of information retrieval systems, a crucial aspect in library and information science.
SRU uses URL query strings, which is similar to web searches. SRW utilizes SOAP, which is more complex but allows for more data exchange.
Installing yaz
Use the apt
instructions
from the prior lesson
to install the yaz
client.
First we need to search for the name of the software:
apt search yaz
The program that we are
interested in is called yaz
.
To get information about the program,
we use the apt show
command:
apt show yaz
The details help confirm that this is the program we want to install. Note that the output also returns a URL to the program's homepage on the web. Visit that link to read more about the software.
To install it,
we use the sudo apt install
command:
sudo apt install yaz
Documentation
The documentation for the
yaz-client
can be accessed
via its manual page or on the web.
See:
man yaz-client
For attribute documentation:
man bib1-attr
The Library of Congress also provides an overview of the bib1-attr, but it's less comprehensive:
https://www.loc.gov/z3950/agency/defns/bib1.html
Complete documentation for the
yaz-client
can be found on its
homepage:
https://www.indexdata.com/resources/software/yaz/
Using yaz
The command to start
the yaz
program is
yaz-client
.
Open yaz-client:
yaz-client
This starts a separate command line interface with a new prompt:
Z>
In this new interface,
we can connect to a library's
OPAC or discovery service.
To do so,
we use the open
command
followed by the server address:
open saalck-uky.alma.exlibrisgroup.com:1921/01SAA_UKY
Queries
Queries are constructed using Prefix Query Notation (PQN). In the context of PQN, this is a way of structuring queries where the operator (e.g., AND, NOT, OR) precedes the operands (e.g., search terms, attributes, fields).
Each query begins with a command.
The list of commands are
described in man yaz-client
in the COMMANDS section.
The main command we'll use
is the find
command,
which may be abbreviated
down to the f
command.
Let's see some examples:
Example 1
To find title with word 'information' and the Library of Congress Subject Heading 'library science', we use the following query:
find @and @attr 1=4 "information" @attr 1=21 "library science"
In the above:
find
is the command that sends a search request@and
is the operator signifying a Boolean AND search of multiple attributes@attr 1=4
instructs the query to search for the term in the Title"information"
is the first search term for the Title search@attr 1=21
instructs the query to search for the term in the Subject-heading"library science"
is the second search term for the subject heading search
The search does not reveal the results.
To peruse the results,
we use the show
command.
To show the first record:
show 1
Example 2
Find with subject headings "library science" and "philosophy"
f @and @attr 1=21 "library science" @attr 1=21 "philosophy"
Example 3
Find where personal name is "mcmurtry, larry"
f @attr 1=1 "mcmurtry, larry"
Example 4
Find any for "c programming language"
f @attr 1=1016 "c programming language"
Conclusion
Z39.50 is often presented as an abstract
information retrieval concept
even though it has played a central
part of searching online catalogs and database
for nearly 50 years.
The protocol,
along with tools like yaz
can be used to build
search interfaces to bibliographic data.
For example,
see:
- A Guide to the PHP YAZ Library for Information Retrieval
- Fun with bibliographic indexes, bibliographic data management software, and Z39.50
Creating a LAMP Server
In this section, we learn how to set up a LAMP (Linux, Apache, MySQL, PHP) stack. This stack enables us to create a web server that provides extra funtionality via PHP and MySQL, both of which are required to run content management systems and integrated library systems.
Installing the Apache Web Server
Introduction
In this section, we focus on a fundamental component of the internet's infrastructure: the web server, or alternatively, the HTTP server.
The web server is software that makes websites available. The basic function is to make files accessible on at least one computer to anyone with a web browser. Thus, at a basic level, the web is essentially a world wide file system, and the web browser is essentially a file explorer, like Windows Explorer on Windows or Finder on macOS.
Understanding how an HTTP server functions is crucial for anyone wanting to manage or deploy web services. This session will guide you through installing Apache, one of the most popular web server applications, conducting basic checks to ensure its operation, and creating your first web page.
It's important to understand the basics of an HTTP server, and therefore I ask you to read Apache's Getting Started page before proceeding with the rest of this section. Each of the main sections on that page describe the important elements that make up and serve a website, including:
- clients, servers, and URLs
- hostnames and DNS
- configuration files and directives
- web site content
- log files and troubleshooting
Installation
Before we install Apache, we need to update our systems first.
sudo apt update
sudo apt -y upgrade
Once the machine is updated,
we can install Apache2 using apt
.
First we'll use apt search
to identify
the specific package name.
I already know that a lot of results
will be returned,
so I will pipe the apt search
command
through head
to look at the initial results:
apt search apache2 | head
The package that we're interested in
happens to be named apache2 on Ubuntu.
This package name is not a given.
On other distributions,
like Fedora,
the Apache package is called httpd.
To learn more about the apache2 package,
we can examine it with the apt show
command:
apt show apache2
Once we've confirmed that apache2 is the package
that we want,
we install it with the apt install
command.
Press Y to agree to continue after running
the command below:
sudo apt install apache2
Basic checks
One thing that makes Apache2, and some other web servers, powerful is the library of modules that extend Apache's functionality. We'll come back to modules soon. For now, we're going to make sure the server is up and running, configure some basic things, and then create a basic web site.
To start,
I will use the systemctl
command
to acquire some info about apache2 and
make sure it is enabled and running:
systemctl status apache2
The output shows that apache2 is enabled,
which is the default for this software.
The systemctl
command's use of the term enabled
means that the software
will start automatically on reboot.
However, it may not be running.
The output should state that
the software is active if it is running.
Creating a web page
Since apache2 is running, let's look at the default web page.
There are two ways we can look at the default web page. We can use a text based web browser or a graphical web browser like Firefox, Chrome, etc.
Text Based Web Browser
There are a number of
text based web browsers available.
I like w3m
because it
defaults to Vim keybindings,
but many like elinks
.
To check the site with w3m
,
we have to install it first:
sudo apt install w3m
If you want to try
elinks
, then runsudo apt install elinks
.
Once the text based browser is installed, we can visit our default site using its loopback IP address (aka, localhost). From the command line on our server, we can run either of these two commands:
w3m 127.0.0.1
Or:
w3m localhost
We can also get the system's private IP address
using the ip a
command.
This address will begin with the number 10 and
look like 10.128.0.99.
To use that with w3m
from the
virtual machine's command line,
we run:
w3m 10.128.0.99
If the apache2 installed and started correctly, then you should see the following text at the top of the screen:
Apache2 Ubuntu Default Page
It works!
To exit w3m
,
press q and then y to confirm exit.
Graphical Browser
To view the default web page using a regular web browser, like Firefox, Chrome, Safari, Edge, or etc., you need to get your server's public IP address. To do that, log into the Google Cloud Console. In the left hand navigation panel, hover your cursor over the Compute Engine link, and then click on VM instances. You should see your External IP address in the table on that page. You can copy that external IP address or simply click on it to open it in a new browser tab. Then you should see the graphical version of the Apache2 Ubuntu Default Page.
Note that most browsers nowadays may try to force HTTPS mode, and they also often hide the protocol from the URL. If your web page is not loading, make sure your URL is http://IP-ADDRESS and not https://IP-ADDRESS.
Please take a moment to read through the text on the default page. It provides important information about where Ubuntu stores configuration files and what those files do, and the document root, which is where website files are stored.
Create a Web Page
Let's create our first web page. The default page described above provides the location of the document root at /var/www/html. Remember that the web is, at its simplest, a filesystem that has been made available to the wide world. The web server is what provides access to part of the filesystem. That point of access is called the document root, which may be on a different location on a different machine, configured to be at a different location than the default, or web servers may also be configured to expose multiple parts of the filesystem to the web.
When we navigate to the document root on the command line, we'll see that there is already an index.html file located in that directory. This is the Apache2 Ubuntu Default Page that we visited above in our browsers. Let's rename that index.html file, and create a new one:
cd /var/www/html/
sudo mv index.html index.html.original
sudo nano index.html
Note: we use
sudo
in this directory because we are working on files and directories outside our home directories. Thus, be careful here about the commands you run. Any mistake may result in deleting necessary files or directories.
If you know HTML,
then feel free to write some
basic HTML code to get started.
Otherwise, you can re-type the content below
in nano
, and
then save and exit out.
<html>
<head>
<title>My first web page using Apache2</title>
</head>
<body>
<h1>Welcome</h1>
<p>Welcome to my web site.
I created this site using the Apache2 HTTP server.</p>
</body>
</html>
If you have your site open in your web browser, reload the page, and you should see the new text.
You can still view the original default page by specifying its name in the URL. Remember that web browsers are, at their most basic, simply file viewers. So it makes sense that you simply have to specify the name of the file you want to view. For example, if your external IP address is 55.222.55.222, then you'd specify it like so:
http://55.222.55.222/index.html.original
Conclusion
In this section,
we learned about the Apache2 HTTP server.
We learned how to install it on Ubuntu,
how to use a systemctl
command
to check its status,
how to create a basic web page in /var/www/html
,
how to view that web page using the w3m
command line browser and
our regular graphical browser,
In the next section, we will install PHP, which will provide the language needed to connect to MySQL, and thus enable more data driven web sites.
Installing and Configuring PHP
Introduction
Client-side programming languages, like JavaScript, are handled by the browser. Major browsers like Firefox, Chrome, Safari, Edge, etc. all include JavaScript engines that use just-in-time compilers to execute JavaScript code (Mozilla has a nice description of the process.) From an end user's perspective, you basically install JavaScript when you install a web browser.
PHP, on the other hand, is a server-side programming language, which means it must be installed on the server in order to be used. From a system or web administrator's perspective, this means that not only does PHP have be installed on a server, but it must also be configured to work with the HTTP server, which in our case is Apache2.
The main use of PHP is to interact with databases, like MySQL, MariaDB, PostgreSQL, etc., in order to create data-based page content. To begin to set this up, we have to:
- Install PHP and relevant Apache2 modules
- Configure PHP and relevant modules to work with Apache2
- Configure PHP and relevant modules to work with MySQL
Install PHP
As usual, we will use apt install
to install PHP and relevant modules.
Then we will restart Apache2
using the systemctl
command.
Use apt show [package_name]
to read more about each package
we will install.
The first command below installs
the php and the libapache2-mod-php
packages.
The latter package is used to
create a connection between PHP
and Apache2.
sudo apt install php libapache2-mod-php
sudo systemctl restart apache2
We can check its status and see if there are any errors:
systemctl status apache2
Check Install
To check that it's been installed and that
it's working with Apache2,
we can create a small PHP file in our
web document root.
To do that,
we cd
to the /var/www/html/
directory
and create a file called info.php:
cd /var/www/html/
sudo nano info.php
In that file, add the following text, then save and close the file:
<?php
phpinfo();
?>
No visit that file using the external IP address for your server. For example, in Firefox, Chrome, etc, go to:
http://55.333.55.333/info.php
Again, be sure to replace the IP below with the IP address of your server and be sure to use http and not https.
You should see a page that provides system information about PHP, Apache2, and the server. The top of the page should look like Figure 1 below:
Basic Configurations
By default, when Apache2 serves a web page,
it looks for and serves a
file titled index.html,
even if it does not display that file in the URL bar.
Thus, http://example.com/
actually
resolves to http://example.com/index.html
in such cases.
However, if our plan is to provide for PHP,
we want Apache2 to default to a file
titled index.php instead of
index.html file.
To configure that,
we need to edit the dir.conf file
in the /etc/apache2/mods-enabled/ directory.
In that file there is a line that starts with
DirectoryIndex.
The first file in that line is index.html, and then
there are a series of other files that Apache2 will
look for in the order listed.
If any of those files exist in the document root,
then Apache2 will serve those before proceeding to the next.
We simply want to put index.php first and let
index.html be second on that line.
Before modifying this file,
it's good practice to create a backup
of the original.
So we will use the cp
command
to create a copy with a new name,
and then we will use nano
to edit the file.
cd /etc/apache2/mods-enabled/
sudo cp dir.conf dir.conf.bak
sudo nano dir.conf
Next we change the line to this:
DirectoryIndex index.php index.html index.cgi index.pl index.xhtml index.htm
Whenever we make a configuration change,
we can use the apachectl
command to
check our configuration:
apachectl configtest
If we get a Syntax Ok message, we can reload the Apache2 configuration and restart the service:
sudo systemctl reload apache2
sudo systemctl restart apache2
Create an index.php File
Now create a basic PHP page.
cd
back to the Apache2
document root directory and
use nano
to create and
open an index.php
file:
cd /var/www/html/
sudo nano index.php
Let's add some HTML and PHP to it. We will add PHP that functions as a simple browser detector. Add the following code:
<html>
<head>
<title>Broswer Detector</title>
</head>
<body>
<p>You are using the following browser to view this site:</p>
<?php
$user_agent = $_SERVER['HTTP_USER_AGENT'];
if(strpos($user_agent, 'Edge') !== FALSE) {
$browser = 'Microsoft Edge';
} elseif(strpos($user_agent, 'Firefox') !== FALSE) {
$browser = 'Mozilla Firefox';
} elseif(strpos($user_agent, 'Chrome') !== FALSE) {
$browser = 'Google Chrome';
} elseif(strpos($user_agent, 'Opera Mini') !== FALSE) {
$browser = "Opera Mini";
} elseif(strpos($user_agent, 'Opera') !== FALSE) {
$browser = 'Opera';
} elseif(strpos($user_agent, 'Safari') !== FALSE) {
$browser = 'Safari';
} else {
$browser = 'Unknown';
}
if(strpos($user_agent, 'Windows') !== FALSE) {
$os = 'Windows';
} elseif(strpos($user_agent, 'Linux') !== FALSE) {
$os = 'Linux';
} elseif(strpos($user_agent, 'Mac') !== FALSE) {
$os = 'Mac';
} elseif(strpos($user_agent, 'iOS') !== FALSE) {
$os = 'iOS';
} elseif(strpos($user_agent, 'Android') !== FALSE) {
$os = 'Android';
} else {
$os = 'Unknown';
}
if($browser === 'Unknown' || $os === 'Unknown') {
echo 'No browser detected.';
} else {
echo 'Your browser is ' . $browser . ' and your operating system is ' . $os . '.';
}
?>
</body>
</html>
Next, save the file and exit nano
.
In your browser,
visit your external IP address site
(again, replace your server's IP address):
http://55.333.55.333/
Although your index.html file still exists in your document root, Apache2 now returns the index.php file instead. However, if for some reason the index.php was deleted, then Apache2 would revert to the index.html file since that's what is listed next in the dir.conf DirectoryIndex line.
Conclusion
In this section, we installed PHP and configured it work with Apache2. We also created a simple PHP test page that reported our browser user agent information on our website.
In the next section, we'll learn how to complete the LAMP stack by adding the MySQL relational database to our setup.
Installing and Configuring MySQL
Introduction
We started our LAMP stack when we installed Apache2 on Linux, and then we added extra functionality when we installed and configured PHP to work with Apache2. In this section, our objective is to complete the LAMP stack and install and configure MySQL.
If you need a refresher on relational databases, see: Introduction to Relational Databases.
Install and Set Up MySQL
In this section, we'll learn how to install, setup, secure, and configure the MySQL relational database so that it works with the Apache2 web server and the PHP programming language.
First, let's install MySQL Community Server, and then log into the MySQL shell under the MySQL root account.
sudo apt install mysql-server
This should also start and
enable the database server, but
we can check if it's running and enabled
using the systemctl
command:
systemctl status mysql
Next we need to run a post installation script
called mysql_secure_installation
that performs some security checks.
To do that, run the following command:
sudo mysql_secure_installation
When you run the above script, you'll get a series of prompts to respond to like below. As shown below, you will want to remove anonymous users, disallow root login remotely, remove the test database, and reload privileges. Press Y at these prompts.
Remove anonymous users: Y
Disallow root login remotely: Y
Remove test database and access to it: Y
Reload privilege tables now: Y
We can login to the database to test it. In order to do so, we have to become the root Linux user, which we can do with the following command:
sudo su
Note: we need to be careful when we enter commands on the command line, because it's a largely unforgiving computing environment. But we need to be especially careful when we are logged in as the Linux root user. This user can delete anything, including files that the system needs in order to boot and operate.
After we are Linux root,
we can login to MySQL,
run the show databases;
command, and
then exit with the \q
command:
NOTE: we need to distinguish between the regular user prompt of our Linux accounts and the MySQL prompt below. In the following, I will use the greater than symbol > to represent the MySQL prompt. Do not type that prompt when you are using MySQL.
First, connect to the MySQL server as the MySQL root user:
mysql -u root
Then request a list of the databases:
show databases;
And the following databases should be returned:
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
+--------------------+
3 rows in set (0.002 sec)
Note: If we are logging into the root database account as the root Linux user, we don't need to enter our password.
Create and Set Up a Regular User Account
We need to reserve the root MySQL user for special use cases and instead create a regular MySQL user, or more than one MySQL user, as needed.
To create a regular MySQL user,
we use the create
command.
In the command below,
I'll create a new user called opacuser
with a complex password within the single quotes
at the end (marked with a series of Xs here for demo purposes).
From the MySQL prompt:
create user 'opacuser'@'localhost' identified by 'XXXXXXXXX';
If the prompt returns a Query OK message, then the new user should have been created without any issues.
Create a Practice Database
As the root database user, let's create a new database for a regular, new user.
The regular user will be granted all privileges on the new database, including all its tables. Other than granting all privileges, we could limit the user to specific privileges, including: CREATE, DROP, DELETE, INSERT, SELECT, UPDATE, and GRANT OPTION. Such privileges may be called operations or functions, and they allow MySQL users to use and modify the databases, where appropriate. For example, we may want to limit the opacuser user to only be able to use SELECT commands. It totally depends on the purpose of the database and our security risks.
From the MySQL query prompt, run the following commands to create a new database opacdb and to grant all privileges to opacdb to the MySQL user opacuser:
create database opacdb;
grant all privileges on opacdb.* to 'opacuser'@'localhost';
show databases;
Exit out of the MySQL database as the root MySQL user, and then exit out of the root Linux user account, and you should be back to your normal Linux user account:
\q
And then exit out of the Linux root user account:
exit
Note: relational database keywords are often written in all capital letters. As far as I know, this is simply a convention to make the code more readable. However, in most cases I'll write the keywords in lower case letters. This is simply because, by convention, I'm super lazy.
Logging in as Regular User and Creating Tables
We can now start doing MySQL work.
As a reminder,
we've created a new MySQL user named opacuser and
a new database for opacuser that is called opacdb.
When we run the show databases
command as
the opacuser user,
we should see the opacdb database.
Note below that I use the -p
option.
This instructs MySQL to request the password
for the opacuser user, which
is required to log in.
mysql -u opacuser -p
Then from the MySQL prompt, list the available databases and switch to the new opacdb database:
show databases;
use opacdb;
A database is not worth much without data. In the following code, I create and define a new table for our opacdb database. The table will be called books, and it will contain data describing some books. We will keep this table very simple and use only three fields:
create table books (
id int unsigned not null auto_increment,
author varchar(150) not null,
title varchar(150) not null,
copyright date not null,
primary key (id)
);
You can confirm that the table was created by running the following two commands, which lists the available tables and then describes the books table:
show tables;
describe books;
Congratulations! Now create some records for that table.
Adding records into the table
We can populate our opacdb database
with some data.
(I simply picked the first book listed from
the NYTimes best lists of books for the years
2019-2022.)
We'll use the insert
command to add our records
into our distribution table:
insert into books (author, title, copyright) values
('Jennifer Egan', 'The Candy House', '2022-04-05'),
('Imbolo Mbue', 'How Beautiful We Were', '2021-03-09'),
('Lydia Millet', 'A Children\'s Bible', '2020-05-12'),
('Julia Phillips', 'Disappearing Earth', '2019-05-14');
Now we can view all the records
that we just created with the MySQL
select
command:
select * from books;
Success! Now let's test our table.
Testing Commands
We will complete the following tasks to refresh our MySQL knowledge:
- retrieve some records or parts of records,
- delete a record,
- alter the table structure so that it will hold more data, and
- add a record
Reminder: each MySQL command ends with a semi-colon. Some of the following MySQL commands are single-line, but others are multi-line. Regardless if a MySQL command is one-line or multi-line, it doesn't end until it ends with a semi-colon:
select author from books;
select copyright from books;
select author, title from books;
select author from books where author like '%millet%';
select title from books where author like '%mbue%';
select author, title from books where title not like '%e';
select * from books;
alter table books add publisher varchar(75) after title;
describe books;
update books set publisher='Simon \& Schuster' where id='1';
update books set publisher='Penguin Random House' where id='2';
update books set publisher='W. W. Norton \& Company' where id='3';
update books set publisher='Knopf' where id='4';
select * from books;
delete from books where author='Julia Phillips';
insert into books
(author, title, publisher, copyright) values
('Emma Donoghue', 'Room', 'Little, Brown \& Company', '2010-08-06'),
('Zadie Smith', 'White Teeth', 'Hamish Hamilton', '2000-01-27');
select * from books;
select author, publisher from books where copyright < '2011-01-01';
select author from books order by copyright;
\q
Install PHP and MySQL Support
The next goal is to complete the connection between PHP and MySQL so that we can use both for our websites.
First install PHP support for MySQL. We're installing some modules alongside the basic support. These may or may not be needed, but I'm installing them to demonstrate some basics.
sudo apt install php-mysql php-mysqli
And then restart Apache2 and MySQL:
sudo systemctl restart apache2
sudo systemctl restart mysql
Create PHP Scripts
In order for PHP to connect to MySQL, it needs to authenticate itself. To do that, we will create a login.php file in /var/www/html. We also need to change the group ownership of the file and its permissions so that the file can be read by the Apache2 web server but not by the world, since this file will store password information.
cd /var/www/html/
sudo touch login.php
sudo chmod 640 login.php
sudo chown :www-data login.php
ls -l login.php
sudo nano login.php
In the file, add the following credentials. If you used a different database name than opacdb and a different username than opacuser, then you need to substitute your names below. You need to use your own password where I have the Xs:
<?php // login.php
$db_hostname = "localhost";
$db_database = "opacdb";
$db_username = "opacuser";
$db_password = "XXXXXXXXX";
?>
Next we create a new PHP file for our website. This file will display HTML but will primarily be PHP interacting with our books database.
Create a file titled opac.php.
sudo nano opac.php
Then copy over the following text
(I suggest you transcribe it, especially
if you're interested in learning a bit of PHP, but
you can simply copy and paste it into the nano
buffer):
<html>
<head>
<title>MySQL Server Example</title>
</head>
<body>
<h1>A Basic OPAC</h1>
<p>We can retrieve all the data from our database and book table
using a couple of different queries.</p>
<?php
// Load MySQL credentials
require_once 'login.php';
// Establish connection
$conn = mysqli_connect($db_hostname, $db_username, $db_password) or
die("Unable to connect");
// Open database
mysqli_select_db($conn, $db_database) or
die("Could not open database '$db_database'");
echo "<h2>Query 1: Retrieving Publisher and Author Data</h2>";
// Query 1
$query1 = "select * from books";
$result1 = mysqli_query($conn, $query1);
while($row = $result1->fetch_assoc()) {
echo "<p>Publisher " . $row["publisher"] .
" published a book by " . $row["author"] .
".</p>";
}
mysqli_free_result($result1);
echo "<h2>Query 2: Retrieving Author, Title, Date Published Data</h2>";
$result2 = mysqli_query($conn, $query1);
while($row = $result2->fetch_assoc()) {
echo "<p>A book by " . $row["author"] .
" titled <em>" . $row["title"] .
"</em> was released on " . $row["copyright"] .
".</p>";
}
// Free result2 set
mysqli_free_result($result2);
/* Close connection */
mysqli_close($conn);
?>
</body>
</html>
Save the file and exit out of nano
.
Test Syntax
After you save the file and exit the text editor, we need to test the PHP syntax. If there are any errors in our PHP, these commands will show the line numbers that are causing errors or leading up to errors. Nothing will output if all is well with the first command. If all is well with the second command, HTML should be outputted:
sudo php -f login.php
sudo php -f opac.php
Conclusion
Congratulations! If you've reached this far, you have successfully created a LAMP stack. In the process, you have learned how to install and set up MySQL, how to create MySQL root and regular user accounts, how to create a test database with play data for practicing, and how to connect this with PHP for display on a webpage.
In regular applications of these technologies, there's a lot more involved, but completing the above process is a great start to learning more.
Creating a Bare Bones OPAC
In this section, we're going to create a bare bones and very basic OPAC. The idea is simply to acquire an intuition and understanding of how data from a relational database is retrieved and entered using various technologies.
A real integrated library system is much more complex than what we are doing here, but the fundamental ideas are the same: we enter data into a database, and we retrieve data from a database. And then a whole slew of other technologies are added to present the data in a user-friendly way: HTML, CSS, and JavaScript.
Integrated library systems (ILS) also provide multiple modules for patron management, acquisitions, circulation, cataloging, serials management, authorities, reporting, and so forth (see Koha: About). All those modules rely on some kind of underlying relational database, like MySQL (which is what Koha uses). And this results in a complex, interconnected set of tables. We are working with only one table in our database, the books table. In reality, an ILS will rely on dozens of tables.
In the prior section, we created a MySQL database called opacdb. That database has one table, called books. Then we created a file that used PHP to retrieve the data from the books table and present it on a web page.
In this section, we are going to use different PHP code that will allow us to search the books table and retrieve results based on our search query. In this way, we are more closely mimicking an OPAC, even though we're still far from creating anything that's full fledged.
Creating the HTML Page and a PHP Search Page
The first thing we do is create a basic HTML page that contains a form for entering queries. We'll call this HTML page with the form mylibrary.html. When a user clicks on the submit button in the form, the form will activate a PHP script called search.php. That search.php will establish a connection to the OPAC database that we already have created. Our PHP script will contain a special MySQL query that will allow us to search all the fields in our books table. Then it will iterate through each row of the books table and return results that match our query. We also add two date fields to our form to limit results by publication dates, which we labeled as copyright in our MySQL books table.
HTML Form
Here is the HTML for our search page, titled mylibrary.html:
<html>
<head>
<title>MySQL Server Example</title>
</head>
<body>
<h1>A Basic OPAC</h1>
<p>In the form below,
<b>optionally</b> enter text in the search field.
You can search by author, title, or publisher.
Capitalization is not necessary.
It's okay to enter partial information,
like part of an author's, title's, or publisher's name.</p>
<p>The date fields are <b>required</b>.
You can use the date fields to limit results.
I added some extra records,
which you can view to know what you can query:</p>
<p><a href="http://11.111.222.222/opac.php">http://11.111.222.222/opac.php</a></p>
<p>This is very much a toy,
stripped down
<a href="https://en.wikipedia.org/wiki/Online_public_access_catalog">OPAC</a>.
The records are basic.
Not only do they not conform to
<a href="https://www.loc.gov/marc/">MARC</a>,
but they don't even conform to something
as simple as
<a href="https://www.dublincore.org/">Dublin Core</a>.
<p>I also don't provide options
to select different fields,
like author, title, or publisher fields.
Instead the search field below searches
all the fields
(author, title, publisher)
in our <b>books</b> table.</p>
<p>The key idea is to get a sense
of how an OPAC works, though.</p>
<h2>My Basic Library OPAC</h2>
<form method="post" action="search.php">
<label for="search">Search:</label>
<input type="text" name="search" id="search">
<br>
<label for="start_date">Start Date:</label>
<input type="date" name="start_date" id="start_date">
<br>
<label for="end_date">End Date:</label>
<input type="date" name="end_date" id="end_date">
<br>
<input type="submit" value="Search">
</form>
</body>
</html>
PHP Search Script
Here is the PHP for our search script, which should be named search.php:
<?php
// Load MySQL credentials
require_once 'login.php';
// Establish connection
$conn = mysqli_connect($db_hostname, $db_username, $db_password) or
die("Unable to connect");
// Open database
mysqli_select_db($conn, $db_database) or
die("Could not open database '$db_database'");
// Check if search query was submitted
if (isset($_POST['search'])) {
// Sanitize user input to prevent SQL injection attacks
$search = mysqli_real_escape_string($conn, $_POST['search']);
// Get the start and end dates for the date range
$start_date = mysqli_real_escape_string($conn, $_POST['start_date']);
$end_date = mysqli_real_escape_string($conn, $_POST['end_date']);
// Build the MySQL query with a WHERE
// clause that includes the date range filter
$query = "SELECT * FROM books WHERE
(author LIKE '%$search%' OR
title LIKE '%$search%' OR
publisher LIKE '%$search%') AND
copyright BETWEEN '$start_date' AND '$end_date'";
// Execute the query
$result = mysqli_query($conn, $query);
// Check if any results were returned
if (mysqli_num_rows($result) > 0) {
// Loop through the results and output them
while ($row = mysqli_fetch_assoc($result)) {
echo "ID: " . $row["id"] . "<br>";
echo "Author: " . $row["author"] . "<br>";
echo "Title: " . $row["title"] . "<br>";
echo "Publisher: " . $row["publisher"] . "<br>";
echo "Copyright: " . $row["copyright"] . "<br><br>";
}
} else {
echo "No results found.";
}
// Free up memory by closing the MySQL result set
mysqli_free_result($result);
}
// Close the MySQL connection
mysqli_close($conn);
echo "<p>Return to search page: <a href='http://11.111.222.222/mylibrary.html'>http://11.111.222.222/mylibrary.html</a></p>";
?>
Modifications
Replace the example IP address (11.111.222.222 above) with the external IP address of your machine. Add more records, using MySQL, to your books table, and test your queries.
To add records to your books table, recall that we used the insert into MySQL statements. Here's the example from the prior lesson. Use it to add titles that are of interest to you.
First connect to the MySQL server:
mysql -u opacuser -p
Then run the insert
command with
the data for the new records:
insert into books
(author, title, publisher, copyright) values
('Emma Donoghue', 'Room', 'Little, Brown \& Company', '2010-08-06'),
('Zadie Smith', 'White Teeth', 'Hamish Hamilton', '2000-01-27');
Conclusion
In this lesson, we created a very bare bones OPAC simply to express the fundamental idea of how data is stored and retrieved on the web. In reality, what separates an OPAC, or a discovery service in a modern integrated library system or library service platform, from other databases on the web is the structure of the records that are stored in the relational database. Such records are structured using MARC. Our records are very simply structured, but still, I hope this helps in creating an intuition about how OPACs and like function. In the next section, we will learn how to enter data into our catalog, thereby mimicking the cataloging module of an integrated library system.
Creating a Bare Bones Cataloging Module
If you have worked with an integrated library system (or took my electronic resource management class), then you know that an OPAC is simply one module out of several that makeup an integrated library system (ILS). Integrated library systems, and the newer library service platforms (LSP), provide other modules for other types of work. These include modules for acquisitions, authority files, circulation, course reserves, patron management, and more. In the prior section, we created one of those modules: a bare bones OPAC. In this section, we are going to create a bare bones cataloging module in the same kind of way.
Up until this point, you have been adding records to your OPAC using the MySQL command interface. But unless you are a full time database administrator or programmer, it's unlikely that you would add data to your system via that interface. Instead you would use an application via a fancy graphical user interface, i.e., integrated library system. The reason we started off with MySQL is not because you would necessarily use this interface on a daily basis. Rather, it's because I want you to understand the foundations of these technologies.
Creating the HTML Page and a PHP Cataloging Page
Like in the last exercise, the first thing we do is create a basic HTML page that contains a form for entering our bibliographic data. Again, our cataloging module will not be real world like. The goal here is to build an intuition about how these technologies work and to provide some grounding if you do want to pursue a more technical path.
The form that we will create needs to mirror the data structure in the books table that we created in our prior lesson. That means it will only contain four fields:
- author
- title
- publisher
- copyright
I'll call this page index.html. I'll create a new directory for this module:
cd /var/www/html
sudo mkdir cataloging
Then I'll use nano to create the index.html file and add the content:
cd cataloging
sudo nano index.html
In index.html, we add the following content:
<!DOCTYPE html>
<html>
<head>
<title>Enter Records</title>
</head>
<body>
<h1>OPAC Library Administration</h1>
<p>This is the library administration page for entering records into the OPAC.</p>
<p>Please do not use this page unless you are an authorized cataloger.</p>
<form action="insert.php" method="post">
<label for="author">Author:</label>
<input type="text" name="author" id="author" required><br><br>
<label for="title">Book Title:</label>
<input type="text" name="title" id="title" required><br><br>
<label for="publisher">Publisher:</label>
<input type="text" name="publisher" id="publisher" required><br><br>
<label for="copyright">Copyright:</label>
<input type="date" id="copyright" name="copyright">
<input type="submit" value="Submit">
</form>
</body>
</html>
PHP Insert Script
The index.html page will provide a user interface, that is, a form, for entering our bibliographic data. However, the PHP script is needed to communicate and add the data from our form into our MySQL database and books table.
Also, just as the HTML form has to match the data structure of the books table, the PHP script also needs to match the form from the HTML page and the data structure in the books table.
Here is the PHP script, which I call insert.php, which you'll notice was referenced in the HTML code above:
<?php
// Load MySQL credentials
require_once '../login.php';
// Establish connection
$conn = mysqli_connect($db_hostname, $db_username, $db_password) or
die("Unable to connect");
// Open database
mysqli_select_db($conn, $db_database) or
die("Could not open database '$db_database'");
// Prepare and bind SQL statement
$stmt = $conn->prepare("INSERT INTO books (author, title, publisher, copyright) VALUES (?, ?, ?, ?)");
$stmt->bind_param("ssss", $author, $title, $publisher, $copyright);
// Set parameters and execute statement
$author = $_POST["author"];
$title = $_POST["title"];
$publisher = $_POST["publisher"];
$copyright = $_POST["copyright"];
if ($stmt->execute() === TRUE) {
echo "New record created successfully";
} else {
echo "Error: " . $stmt->error;
}
// Close statement and connection
$stmt->close();
$conn->close();
echo "<p>Return to the cataloging page: <a href='http://11.111.111.111/cataloging/'>http://11.111.111.111/cataloging/</a></p>";
?>
Security
Since our HTML and PHP files allow us to enter data into our MySQL database from a simple web interface, we need to limit access to the module. Again, in a real-world situation, modules like these would have a variety of security measures in place to prevent wrongful data entry. In our case, we will rely on a simple authorization mechanism provided by the Apache2 server called htpasswd.
First, we create an authentication file in our /etc/apache2 directory, which is where the Apache2 web server stores its configuration files. The file will contain a hashed password and a username we give it. In the following command to set the password, I set the username to libcat, but it could be anything:
sudo htpasswd -c /etc/apache2/.htpasswd libcat
Next we need to tell the Apache2 web server
that we will use the htpasswd
to control
access to our cataloging module.
To do that,
we use nano
to open the apache2.conf file.
We need
sudo nano /etc/apache2/apache2.conf
In the apache2.conf file, look for the following code block / stanza. We are interested in the third line in the stanza, which is line 172 for me, and probably is for you, too.
<Directory /var/www/>
Options Indexes FollowSymLinks
AllowOverride None
Require all granted
</Directory>
Carefully, we need to change the word None to the word All:
<Directory /var/www/>
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
Next, change to the cataloging directory and
use nano
to create a file called .htaccess
(note the leading period):
cd /var/www/html/cataloging
sudo nano .htaccess
Add the following content to .htaccess:
AuthType Basic
AuthName "Authorization Required"
AuthUserFile /etc/apache2/.htpasswd
Require valid-user
Check that the configuration file is okay:
apachectl configtest
If you get a Syntax OK message, then restart Apache2 and check its status:
sudo systemctl restart apache2
systemctl status apache2
Permissions and Ownership
The Apache2 web server has a user account on your Linux server. The account name is www-data, and it's account details are stored in the /etc/passwd file:
grep "www-data" /etc/passwd
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
From the output,
we can see that the
www-apache user's home directory
is /var/www and
its default shell is /usr/sbin/nologin.
See man nologin
for details, but
in short,
the nologin
prevents the
www-data account to be able
to login to a shell.
You can compare the output of the above
grep
command with your account information that is stored in /etc/passwd. Use the following command:grep $USER /etc/passwd
to do so. You'll see, for example, that your home directory is listed there as well as your default shell, which isbash
.
The benefit with having Apache2 a user is that we can limit file permissions and ownership to this user.
The general guidelines for this are as follows:
- Static files (like HTML, CSS, JS) might not need to be writable by the Apache server, so they could be owned by a different user (like your own user account) but be readable by www-data.
- Directories where Apache needs to write data (like upload directories) or applications that need write access should be owned by www-data.
- Configuration files (incl. files like login.php) should be readable by www-data but not writable, to prevent unauthorized modifications.
We can initiate this guidelines
with the chown
and chmod
commands:
-
Change the group ownership of /var/www/html to www-data:
sudo chown :www-data /var/www/html
-
Set the setgid bit on /var/www/html. This command makes it so that any new files and directories created within /var/www/html will inherit the group ownership of the parent directory (www-data, in this case). While this ensures that group ownership is inherited, the user ownership of new files will still be the user that creates the files. In our case, since we use
sudo
to work in this directory, that means that the user owner for subsequent files and directories will be the Linux root user.sudo chmod -R g+s /var/www/html
Get Cataloging!
Now visit your cataloging module.
You should be required to enter the username
and password that you created with htpasswd
.
Conclusion
In the last lesson, we created a very bare bones OPAC that would allow patrons to search our catalog. In this lesson, we learned how to create a bare bones cataloging module that would allow librarians to add bibliographic data and records to the OPAC.
Now try this:
- Add some records using the above form, and then return to your OPAC and conduct some queries to confirm that the new records have been added.
- Use the MySQL command line interface to view the new records, just like we did a couple of lessons ago.
In a production level environment, we would add quite a bit more functionality and security. Our MySQL database would contain many more tables that allow storing data related to the modules listed above. We would also like to make our modules graphically attractive and provide more content. That would mean we would add Cascading Style Sheets (CSS) and JavaScript to create an attractive and usable interface. But that would be a whole other class.
Installing Content Management Systems
Many library websites are compositions of interconnected resources. For example, a library may have a front-facing website that provides basic information about the library, its physical locations, and its services. That front-facing website may be connected to an integrated library system (ILS) or library service platform (LSP) that is itself a different website. The front-facing website may also be connected to other sites that provide access to all sorts of databases. In the end, this means that a library website is not just one place. It is much more like a series of interconnected buildings, each of which has its own entry points.
In this section, we will learn how to build these interconnected resources. First, we learn how to use WordPress to setup a library's front-facing web presence. The basic process is similar to the process we used when building our bare bones OPAC. We will then use the instructions for the WordPress install to install and configure Omeka, which we might imagine is used to build a digital library for our library.
At the end of this section, we will have begun creating a library web presence that is more than a basic front-facing web presence. Instead, it will start the infrastructure for an ecosystem that provides access to all sorts of library resources.
Install WordPress
Introduction
WordPress is a free and open source content management system (CMS). Originally, its focus was on providing a platform for blogging, but throughout the last decade plus, it has become a general purpose CMS that can serve as a website builder. Two sites exist to provide access to WordPress: WordPress.com and WordPress.org. WordPress.com is a hosting solution, which means that customers can sign up and create a free WordPress site. Since its hosted, customers are only responsible for their content and not for managing the core WordPress installation and its updates. Various paid plans can extend the functionality offered to WordPress.com customers.
WordPress.org is maintained by the WordPress Foundation, which oversees the development of the software and which provides access to the WordPress software. When we download the WordPress software, we download it from WordPress.org. Unlike the hosted solution, when we install and setup WordPress on our own servers, we become responsible for administrating its installation and for keeping the software updated.
WordPress is widely used software, and because of that, it's often the focus of attack. Take a moment to read about the developers's efforts to protect WordPress: Security. We will not need to update our WordPress installs during the course of this course, but you should be familiar with the update process in case you decide to maintain your install or an install at a future date: Updating WordPress.
Libraries and WordPress
Many libraries use WordPress as as their main website and a quick web search will reveal them. For example, I quickly found an example of a (beautiful) WordPress library site for the Reading Public Library (RPL) in Massachusetts. These library websites coordinate with additional solutions that provide integrated library systems and other electronic resource services. RPL, for instance, connects their WordPress installation, which serves as their main website page, with the open source Evergreen ILS, which serves their OPAC. Check this by clicking on RPL's Library Catalog link, and you will see that it takes you to a different URL.
Aside: it is this need to coordinate so many services across all these websites that in part drives the need to develop standards for data exchange and work flow processes. For those of you have taken my electronic resource management course, you will recall we spent an entire module on this topic.
Many library websites are partitioned like this. Thus, when we install WordPress soon, it is as if we are only installing the front entrance to the library. Libraries are generally like this. They have one main website (like https://libraries.uky.edu) but then connect to other sites that provide access to OPACS, discovery systems, OverDrive or other eBook vendors, bibliographic databases, and more. This is part of the confusion around how libraries provide electronic resources. There are efforts to make all these components connect more seamlessly (e.g., through discovery systems), but if we were to model this to the walking around world, it would be like having a library that has multiple buildings, where each building provides one thing: one building for books, one building for journals, another building for other journals, another building for another set of journals, another building for looking up where to find journals, another building for special collections, and so on. I digress.
You can read the announcement about RPL's WordPress launch at: Reading Public Library Launches New WordPress Site. The announcement describes how various plugins were used to offer patrons additional functionality and describes other basic changes that come with the new site. The plugins they added display business hours and help manage events and event attendees.
Plugins are often used with WordPress sites to offer all sorts of additional capabilities. Currently, there are nearly 60 thousand plugins available for WordPress, but some are of higher quality and utility than others. In addition to the thousands of available plugins, there are nearly 12 thousand free themes for WordPress sites. Plus, many businesses offer paid themes or can offer customized themes based on customer needs. These themes can drastically alter the appearance and usability of a WordPress site or cater a site for a specific clientele, such as a library.
Installation
So far I have shown you how to install software using two methods:
- using the
apt
command - downloading from GitHub
In this lesson,
we are going to install WordPress by
downloading the most recent version
from WordPress.org
and installing it manually.
The WordPress application is available
via the apt
command, but
the apt
process makes it a bit more
confusing than it should be, oddly.
We are going to kind of follow the documentation provided by WordPress.org. You should read through the documentation before following my instructions, but then follow the process I outline here instead because the documentation uses some different tools than we'll use.
Another reason we do this manually is because it builds on what we have learned by building our bare bones ILS. That is, the two processes are similar. In both cases, we create a specific database for our platform, we create a specific user for that database, and we provide login credentials in a specific file.
First, read through but don't follow the following instructions:
Customized Installation Process
After you have read through the WordPress.org documentation, follow the steps below to complete the manual install:
Step 1: Requirements
All major software has dependencies.
For example, our bare bones OPAC depends on
MySQL and PHP to provide the database (MySQL) and
the glue (PHP) between our HTML and the database.
The same is true for WordPress.
However, since WordPress is much more complicated
software than our bare bones OPAC,
its dependencies are stricter.
This means that when
we plan to download software outside
of the apt
ecosystem,
we need to make sure that our systems
meet the requirements for our installation.
The WordPress.org Requirements page
states that the WordPress installation requires
at least PHP version 7.4 and MySQL version 5.7.
We can check that our systems meet these
requirements with the following commands:
php --version
mysql --version
The output from php --version
shows that our systems
have PHP 7.4.3,
which is greater than PHP 7.4.
The output from mysql --version
show that our systems
have MySQL 8.0.36,
which is greater than MySQL 5.7.
This means we can proceed.
Next, we need to add some additional PHP
modules to our system to let WordPress operate
at full functionality.
We can install these using the apt
command:
sudo apt install php-curl php-xml php-imagick php-mbstring php-zip php-intl
Then restart Apache2 and MySQL:
sudo systemctl restart apache2
sudo systemctl restart mysql
Step 2: Download and Extract
The next step is to download and
extract the WordPress software,
which is downloaded as a tar.gz file.
This is a compressed archive file,
and is very much like a compressed
zip file.
Although we only download one file,
when we extract it with the tar
command,
the extraction will result in a new directory
that contains multiple files and subdirectories.
The general instructions include:
- Change to the /var/www/html directory.
- Download the latest version of WordPress using the
wget
program. - Extract the package using the
tar
program.
Specifically, we do the following on the command line:
cd /var/www/html
sudo wget https://wordpress.org/latest.tar.gz
sudo tar -xzvf latest.tar.gz
As noted in the WordPress documentation, this will create a directory called wordpress in the same directory. Therefore the full path of your installation will located at /var/www/html/wordpress
Step 3: Create the Database and a User
The WordPress documentation describes how to use phpMyAdmin to create the database and a user for WordPress. phpMyAdmin is a graphical front end to the MySQL relational database that you would access through the browser. We are not going to install that because I like to minimize the software that we install on servers to reduce the server's security exposure. Though you can use phpMyAdmin from a different machine and connect to the server, this is a command line class anyway. Therefore, we are going to create the WordPress database and a database user using the same process we used to create a database and user for our bare bones OPAC. You already know this, but the general instructions are:
- Switch to the root Linux user
- Login as the MySQL root user
Specifically, we do the following on the command line:
sudo su
mysql -u root
The mysql -u root
command places
us in the MySQL command prompt.
The next general instructions are to:
- Create a new user for the WordPress database
- Be sure to replace the Xs with a strong password
- Create a new database for WordPress
- Grant all privileges to the new user for the new database
- Examine the output
- Exit the MySQL prompt
Specifically, this means the following (be sure to replaces the Xs with a unique and strong password of your own):
create user 'wordpress'@'localhost' identified by 'XXXXXXXXX';
create database wordpress;
grant all privileges on wordpress.* to 'wordpress'@'localhost';
show databases;
\q
Step 4: Set up wp-config.php
When we created our bare bones OPAC, we created a file called login.php that contained the name of the database (e.g., opacdb), the name of the database user (e.g., opacuser), and the user's password. WordPress follows a similar process, but instead of login.php, it uses a file called wp-config.php.
Follow these general steps:
- Change to the wordpress directory, if you haven't already.
- Copy and rename the wp-config-sample.php file to wp-config.php.
- Edit the file and add your WordPress database name, user name, and password in the fields for DB_NAME, DB_USER, and DB_PASSWORD.
This means that we specifically do the following:
cd /var/www/html/wordpress
sudo cp wp-config-sample.php wp-config.php
sudo nano wp-config.php
Using nano
,
add your database name, user, and password
in the appropriate fields,
just like we did with our login.php file
for our bare bones OPAC.
Additionall, we want to disable FTP uploads to the site. To do that, navigate to the end of the file and add the following line:
define('FS_METHOD','direct');
Step 5: Optional
The WordPress files were installed at /var/www/html/wordpress. This means that your site would be located at a URL like:
http://11.111.111.11/wordpress
If you want to, you can rename your wordpress directory to something else. The WordPress documentation uses blog as an example. But it could be something else, like the name of a fictional library that you might be using WordPress to build a site. If you decide to change it, be sure to keep the name lowercase and one word (no spaces and only alphabetic characters). For example, if I want to change mine to blog, then:
sudo mv /var/www/html/wordpress /var/www/html/blog
Step 6: Change File Ownership
WordPress will need to write to files
in the base directory.
Assuming your still in your base directory,
whether that is /var/www/html/wordpress
or
/var/www/html/blog
or like,
run the following command:
sudo chown -R www-data:www-data /var/www/html/wordpress
Step 7: Run the Install Script
The next part of the process takes place in the browser. The location (URL) that you visit in the browser depends on your specific IP address and also includes the directory in /var/www/html that we extracted WordPress to or that you renamed if you followed Step 5. Thus, if my IP address is 11.111.111.11 and I renamed my directory to blog, then I need to visit the following URL:
http://11.111.111.11/blog/wp-admin/install.php
IF I kept the directory named wordpress, then this is the URL that I use:
http://11.111.111.11/wordpress/wp-admin/install.php
Finishing installation
From this point forward, the steps to complete the installation are exactly the steps you follow using WordPress's documentation.
Most importantly, you should see a Welcome screen where you enter your site's information. The site Username and Password should not be the same as the username and password you used to create your WordPress database in MySQL. Rather, the username and password you enter here are for WordPress users; i.e., those who will add content and manage the website.
Two things to note:
We have not setup Email on our servers. It's quite complicated to setup an email server correctly and securely, but it wouldn't work well without having a domain name setup anyway. So know that you probably should enter an email when setting up the user account, but it won't work.
Second, when visiting your site, your browser may throw an error. Make sure that the URL is set to http and that it's not trying to access https. Setting up an https site also generally requires a domain name, but we are not doing that here. So if there are any problems accessing your site in the browser, be sure to check that the URL starts off with http.
Conclusion
Congrats on setting up your WordPress library site. It's now time to explore and build a website. Use free themes and free plugins to alter the look of the site, its usability, and its functionality. Try to create a nice looking website. Generally, your goal for the next week is to create an attractive, yet fictional, front entrance for a library website. It's also a break from the command line!
Install Omeka
Omeka is an "Open-source web publishing platforms for sharing digital collections and creating media-rich online exhibits." Most if not all of you have already used Omeka in a prior course. Here our task is not to learn information/knowledge organization, per se, but to learn how to administer the Omeka digital library platform.
The Task
So far we have created a:
- bare bones OPAC/ILS, and
- downloaded, installed, and configured WordPress on our servers.
We will use the same basic process to download, install, and configure Omeka.
Instead of providing comprehensive instructions, your goal is to take what you learned from the bare bones OPAC/ILS and WordPress assignments, and apply them to the Omeka installation and setup. Below are some additional prerequisites that you should complete first. After you've completed them, move on to the General Steps section to remind yourself of the overall process.
You can do it! Be sure to ask and discuss on our chat server.
Prerequisites
When we installed WordPress, we installed most of the prerequisites that Omeka needs, but there are a couple of additional things we need to do.
Some prerequisites:
- Install ImageMagick: this is a suite of utilities to work with photo files. It's used by Omeka to create thumbnail images of any photo uploaded to the digital library. Visit the link above for more information.
sudo apt install imagemagick
- Enable Apache
mod_rewrite
. This is an Apache module used to rewrite URLs. Omeka uses this to create appropriate, user friendly URLs for items and collections in its digital libraries.
sudo a2enmod rewrite
You should be instructed to restart Apache after enabling rewrite:
sudo systemctl restart apache2
General Steps
Below is a list of the general steps you need to use to install Omeka. Generally, you have already completed these steps when you created a bare bones OPAC/ILS and installed WordPress. Your task is to apply what you've learned when doing those prior assignments by completing an Omeka installation on your own. (You can work together and discuss on our chat server.)
Note: let me emphasize that the process is very similar to what we have already done with our bare bones OPAC/ILS and our WordPress installations. Use this handbook to remind you of the specific commands. In short, you are going to complete the following steps:
- Create a new user and a new database in MySQL for the Omeka installation (do not re-use the WordPress database, user, etc credentials or names of databases or tables).
- Use
wget
from your server to download Omeka Classic as a Zip file and extract it in/var/www/html
:- https://github.com/omeka/Omeka/releases/download/v3.1.2/omeka-3.1.2.zip
- unzip it with the
unzip
command, which you might have to install with theapt
command. - the extracted directory will be named omeka-3.1.2. You might want to rename it simply omeka or something else of your choosing. Remember that names of files and directories should not have spaces in them.
- In the extracted directory, find the db.ini file and add your new database credentials. Replace all values containing XXXXXX with the appropriate information. This is the same thing we did with the login.php file for our bare bones OPAC/ILS and the wp-config.php file for WordPress.
- Use the
chown
command like we did with WordPress on thefiles
directory in theomeka
directory. The user and owner should again be www-data. - Restart Apache2 and MySQL
- In your web browser, go to http://your-ip-address/omeka/ and complete the setup via the web form, just like you did with WordPress.
Helpful Links
The user manual below is helpful, but it does not provide explicit instructions.
Be sure to download Omeka Classic and not Omeka S.
- Omeka: https://omeka.org/
- Omeka Classic: https://omeka.org/classic/
- Omeka Classic User Manual: https://omeka.org/classic/docs/
Installing an ILS
In the last section, we built a WordPress site that functions as our library's front-facing presence, and then we built an Omeka site that could serve as our library's digital library. In this section, we complete our infrastructure building by installing the Koha ILS.
Koha is a free and open source library system that provides modules for patron accounts, circulation, cataloging, serials, an OPAC, and more. The process of installing and using Koha is more complicated than the processes we used to installing and using WordPress and Omeka. This is because Koha, like other ILS software, is a complex project that must provide a lot of different functionality for a library and its patrons. Fortunately, the documentation makes the process pretty straightforward. We will rely on that documentation and other resources to install Koha and complete our library's interconnected web presence.
Install the Koha ILS
Koha ILS
Koha is an open source "library management system", otherwise called an integrated library system (ILS). These kinds of systems provide modules that perform specific kinds of functionality. Koha's modules include:
- Administration
- Patron management
- Cash management
- Circulation
- Cataloging
- Course reserves
- Serials
- Acquisitions
- Reports
- OPAC
According to Library Technology Guides, Koha is installed in "4,040 libraries [around the world], spanning 5,677 facilities or branches". Most installations are in medium sized or small libraries. Koha is well represented in academic libraries, but the majority of installations are in public libraries.
Although Koha is an open source ILS and free to download, install, and administer without external support, librarians can hire companies that support open source library management solutions, like ByWater Solutions or the Equinox Open Library Initiative These companies support ILS migration, hosting, training, and more. They also provide support for other library software services, such as open source discovery systems and electronic resource management systems.
In addition to Koha, Evergreen is also an open source integrated library system. According to Library Technology Guides, Evergreen is primarily installed at small and medium size public libraries, and most installations are in the U.S. and Canada.
There is currently a migration to what has been called library service platforms (LSP) in recent years. The LSP is a next generation ILS that is designed from the start to integrate electronic resources. For example, the ILS has an OPAC which was designed to search a library's print collections. Modern OPACs have been adapted for electronic resources, but they are still limited because of the older design model. LSPs use a discovery service instead of an OPAC. Discovery services are designed to search a library's entire collection, including the content in third party databases and journals. Example LSPs include Ex Libris Primo (used by UK Libraries), OCLC's WorldCat Discovery Service, and open source solutions like Aspen Discovery and VuFind.
It is probably unnecessary to state that integration of library systems like the ILS and the LSP is a major part of modern libraries. When we visit a library's website, we will first interact with a normal website that might be built on WordPress, Drupal, or some other content management system. But these websites will link to the public facing components of an ILS or LSP, as well as other services, such as bibliographic database, journal publishers, ebook services, and more. It may therefore be the systems librarians job to help build and connect these services. In this demo, we will continue that work by installing, configuring, and setting up the Koha ILS.
Google Cloud Setup
Before we begin to install Koha, we need to create a new virtual machine instance and configure the Google firewall to allow HTTP traffic to our Koha install.
New Virtual Instance
The virtual instance we have been using does not meet the memory (RAM) needs required by the Koha integrated library system. We therefore need to create a new virtual instance that has more RAM. As a refresher, see the section titled gcloud VM Instance at Using gcloud Virtual Machines. However, we will modify the Series to E2 and set the Machine Type to 2 vCPU, 4 GB memory. All else, including the operating system (Ubuntu 20.04), should remain the same. Note that this is a more expensive setup. Therefore, feel free to delete this instance at the end of the semester.
Google Cloud firewall
Later, after we install Koha, we will need to access the staff interface on a special port for HTTP data. All internet traffic to a server contains metadata that identifies itself by port numbers. The default port for HTTP is 80, and the default port for HTTPS (encrypted) is 443. Since we do not have encryption enabled, this means we will only use port 80, but the staff interface will be identified by port 8080.
How does a server know where to send internet traffic? Internet data is packaged in many forms. One of the most common forms are TCP packets. These packets contain header information that names the source IP, destination IP, source port, and destination port. When TCP packets arrive at a destination server, the operating system inspects the packet header for the port number. The OS then looks up the port number in a table that contains a mapping of ports to applications. When the OS makes the match, it sends the TCP packets to the application. In its default setup, the Apache2 web server handles traffic on port 80.
Firewalls are used to control incoming and outgoing traffic via ports. When we selected Allow HTTP traffic when we created our virtual instance, we instructed the Google Console firewall to allow traffic through port 80. We need to add a firewall rule to allow web traffic through port 8080. We will use port 8080 to access the Koha staff interface.
Please take a moment to read more about ports: What is a computer port? | Ports in networking.
To create a firewall rule to allow traffic to port 8080, go to the Google Cloud Console:
- Click on the hamburger ☰ icon at the top left.
- Click on VPN Network
- Click on Firewall
- At the top of the page, choose Create a firewall rule
(do not choose Create a firewall policy)
- Add name: koha
- Add description: open port 8080
- Next to Targets, click on All instances in the network
- In the Source IPv4 ranges, add 0.0.0.0/0
- Click on Specified protocols and ports
- Click on TCP
- Add 8080 in the Ports box
- Click on Create
Install Koha Repo
Server setup
Now let's log onto our new server and prepare it for the Koha installation.
First we need to update our local repositories:
sudo apt update
And then upgrade our servers:
sudo apt upgrade
The next two commands help save disk space.
The apt autoremove
command "is used
to remove packages that were automatically
installed to satisfy dependencies for other
packages and are now no longer needed
as dependencies changed or the package(s)
needing them were removed in the meantime"
(see man apt
).
The apt clean
command
"clears out the local repository
of retrieved package files" (see man apt-get
).
In the following example,
I combine both commands on one line:
sudo apt autoremove -y && sudo apt clean
Next we need to install gnupg2, which is used to create digital signatures, encrypt data, and aid in secure communication.
sudo apt install gnupg2
At the time of this demo, the update above downloaded a new Linux kernel. Using the new kernel requires a reboot. The reboot command will disconnect you from the server. Just wait a minute or so and then re-connect.
sudo reboot now
Add Koha Repository
When you run the sudo apt update
command,
Ubuntu syncs the local repository database with
several remote repositories.
These remote repositories contain metadata about the
packages they contain.
The syncing process identifies if any new software
updates are available.
The remote repositories are also used to retrieve software.
We can add repositories to sync with and to use to download software, and this includes the Koha ILS. To add the special Koha repository to our system, we use the following command:
Most of the following commands require administrator access. Therefore, I will login as the root user to make it a bit easier. If you do not log in as the root user, be sure to use the
sudo
command.
sudo su
Add the Koha repository to our server:
echo 'deb http://debian.koha-community.org/koha stable main' | sudo tee /etc/apt/sources.list.d/koha.list
We then add the digital signature that verifies the above repo:
wget -q -O- https://debian.koha-community.org/koha/gpg.asc | sudo apt-key add -
Install Koha
Next we need to update/sync the new repository
with the Koha remote repository.
This just means that we use apt update
again.
apt update
Now we view the package information for Koha:
apt show koha-common
And install it:
apt install koha-common
The above command will download and install a lot of additional software, and therefore the process will take several minutes.
Configure Koha
Next we need to edit some configuration files for Koha:
nano /etc/koha/koha-sites.conf
In the above koha-sites.conf file, change the line that contains the following information:
INTRAPORT="80"
To:
INTRAPORT="8080"
Next install and setup mysql-server:
apt install mysql-server
Next we set the root MySQL password (the password below is not an actual password that I use anywhere):
mysqladmin -u root password bibliolib1
When we installed Koha, the Apache2 web server was installed with it as a prerequisite. We need to enable URL rewriting and CGI functionality.
a2enmod rewrite
a2enmod cgi
Now we need to restart Apache2 in the normal way:
systemctl restart apache2
Next we create a database for Koha:
koha-create --create-db bibliolib
We need to tell Apache2 to listen on port 8080:
nano /etc/apache2/ports.conf
And add:
Listen 8080
Make sure Apache configuration changes are valid:
apachectl configtest
If you get an error message, trace the error in the file and line listed.
Let's restart Apache2.
systemctl restart apache2
We'll disable the default Apache2 setup, enable traffic compression using deflate, enable the bibliolib site, and then reload Apache2's configurations and restart again:
a2dissite 000-default
a2enmod deflate
a2ensite bibliolib
systemctl reload apache2
systemctl restart apache2
Koha Web Installer
All the back end work is complete, and like we did with WordPress and Omeka, we can complete the installation through a web installer.
First, get Koha username and password in the following file:
nano /etc/koha/sites/bibliolib/koha-conf.xml
Look for the <config>
stanza (line number 252) and the
line beginning with <user>
(line number 257).
The password is on the line after (line number 258).
Make sure your URL begins with http and not https, and visit the web installer at:
http://IP-ADDRESS:8080
The documentation for the web installer is helpful. One thing to do is to add sample libraries and sample patrons. More generally, be sure to follow instructions as you click through each step.
Introduction to the Koha installation process
Public OPAC
When the install and setup are complete, you will have access to the staff interface. To view the public facing OPAC, you need to make a setting change.
- Click on More in the top drop down box
- Click on Administration
- Click on Global System Preferences
- Click on OPAC in the left hand side bar
- Scroll down to the OPACBaseURL line.
- Enter the IP address of your server: http://IP-ADDRESS
- Click on Save all OPAC Preferences
Once you save these preferences, you should be able to visit your public facing OPAC at the server IP address.
Additional Tasks
Once you've installed and setup Koha, begin to learn the system. Some example tasks:
- Create patron accounts
- Create bibliographic records
- Check out books to patrons
- Delete patron circulation history
Conclusion
In this final section, you learned how to install and setup a Koha ILS installation on a Linux server.
References
Helpful documentation and demos:
- Koha ILS documentation.
- Koha on Debian
- Install Koha on Google Cloud Platform
Conclusion
Accomplishments
In this course, we learned how to:
- work with the Google Cloud console
- install and setup a new Ubuntu Linux server
- use the Linux command line
- use a command line text editor
- search text
- install and manage software
- use Git and GitHub
- build a LAMP server
- create a barebones integrated library system
- install and configure WordPress, Omeka, and Koha sites
- connect these sites to create a full library web presence
In order to avoid continued billing, be sure to stop and delete all virtual machines in your project.