Feed aggregator

Top 10 Best Small Business Credit Card Bonus Offers – April 2024

MyMoneyBlog.com - Mon, 04/29/2024 - 03:28

Updated April 2024. Do you have small business income or work as an independent contractor? Freelance, Uber/Lyft, Amazon, eBay, Etsy, Airbnb? A small business credit card separates your personal and business expenses and can build up your business credit profile. If you are not a corporation or LLC, you can apply as a sole proprietorship, with your name as the business name and your Social Security number as the Tax ID number. These are the top 10 credit card offers that I would personally apply for right now (or have already). Recent changes:

  • Added Platinum 150k, Hilton 175k, AA 75k, Ink Preferred $1,250, United 75k, Alaska 75k, Spark Cash Select $750.
  • Removed Marriott 5FreeNights, Venture X 300k, Hyatt 75k, JetBlue 75k, AmEx Gold 70k, SWPremier 120k

This is a companion post to my Top 10 Best Credit Card Bonus Offers for personal cards. Notice that small business bonuses are on average even higher than those on consumer cards.

The Business Platinum® Card from American Express

  • 150,000 Membership Rewards points after $20,000 on eligible purchases in the first 3 months.
  • HUGE list of additional perks including $400 Dell, $360 Indeed, $150 Adobe, $120 wireless phone annual credits, $200 annual airline fee credit, $189 CLEAR credit, $100 TSA/Global Entry credit, Centurion airport lounge access, and more. See link for details.
  • $695 annual fee. (See Rates and Fees)
  • Terms Apply.

The Hilton Honors American Express Business Card

  • 175,000 Hilton Honors Bonus Points after $8,000 in purchases in the first six months. Offer Ends 6/5. See link for details.
  • Up to $240 in Annual Hilton Credits. Get up to $240 back each year on eligible Hilton purchases made on your Hilton Honors American Express Business Card, with up to $60 in statement credits per quarter.
  • $195 annual fee. (See Rates and Fees)
  • Terms Apply.

Capital One Venture X Business Card

  • 150,000 Miles (worth $1,500 towards travel) after spending $30,000 in the first 3 months. See link for details.
  • $300 annual travel credit. Get up to $300 in statement credits when booking through Capital One Travel.
  • Additional 10,000 bonus miles (equal to $100 towards travel) every year, starting on your first anniversary.
  • Capital One Lounges, Priority Pass(TM) and Plaza Premium Group lounges access.
  • Up to $100 credit towards TSA PreCheck or Global Entry application fee.
  • $395 annual fee.

CitiBusiness / AAdvantage Platinum Select Mastercard

  • 75,000 American Airlines miles after $5,000 in purchases in first the 5 months. See link for details.
  • First checked bag free on domestic AA flights for you and up to 4 companions (Up to $80 value per roundtrip, per person).
  • $0 annual fee for the first year, then $99.

United(SM) Business Card

  • 75,000 bonus United miles after $5,000 in purchases in the first 3 months. Limited-time offer. See link for details.
  • Free first checked bag for both you and a companion (a savings of up to $140 per roundtrip).
  • 5,000-mile “better together” bonus each anniversary when you have both the United(SM) Business Card and personal Chase United credit card.
  • Primary rental car coverage when renting for business purposes.
  • $0 annual fee for the first year, then $99.
  • Subject to 5/24 rule.*

Chase Ink Business Preferred Card

  • 100,000 Ultimate Rewards points (worth $1,000 straight cash back or $1,250 toward travel when redeemed through Chase Travel) after $8,000 in purchases in the first 3 months. See link for details.
  • 3X points on the first $150,000 spent on travel, shipping purchases, internet/cable/phone services, and advertising purchases with social media sites and search engines.
  • Primary rental car coverage when renting for business purposes.
  • $95 annual fee.
  • Subject to 5/24 rule.*

Marriott Bonvoy Business® American Express® Card

  • 3 Free Night Awards (Worth Up To 150K Total Marriott Bonvoy Points) after $6,000 in eligible purchases within first 6 months. Each Free Night Award is worth up to 50,000 Marriott Bonvoy(R) points redemption level. See link for details.
  • New award night top-off option: Marriott now allows you to supplement your free night certificates with up to 15,000 points of your own. For example, the 50k Award can be used to book a hotel at 65,000 points level if you spend 15,000 points of your own. This opens up the number of potential hotels available in expensive areas.
  • Additional Free Night Award upon card anniversary (worth up to 35,000 Bonvoy points). Earn another additional Free Night Award after spending $60K in purchases on your Card in a calendar year.
  • Annual fee is $125. (See Rates and Fees)
  • Terms Apply.

Chase Ink Business Unlimited Card

  • $750 bonus cash back (75,000 Ultimate Rewards points) after $6,000 in purchases in the first 3 months. See link for details.
  • Flat 1.5% cash back on all purchases with no limit.
  • No annual fee.
  • Subject to 5/24 rule.*

Capital One Spark Cash Select Business Card

  • $750 bonus after $6,000 in purchases in the first 3 months. See link for details.
  • Unlimited 1.5% cash back spent on all purchases. with no limit.
  • No annual fee.

Chase Ink Business Cash Card

  • Up to $750 bonus cash back total (75,000 Ultimate Rewards points). Earn $350 when you spend $3,000 on purchases in the first three months and an additional $400 when you spend $6,000 on purchases in the first six months. See link for details.
  • 5% cash back on the first $25,000 spent in combined purchases at office supply stores and on internet, cable and phone services each account anniversary year.
  • No annual fee.
  • Subject to 5/24 rule.*

World of Hyatt Business Card

  • 60,000 Hyatt points after $5,000 in purchases in the first 3 months.
  • Up to $100 in Hyatt statement credits – spend $50 or more at any Hyatt property and earn $50 statement credits up to two times each anniversary year.
  • $199 annual fee.
  • Subject to 5/24 rule.

American Express® Business Gold Card

  • 70,000 Membership Rewards points after $10,000 in eligible purchases in the first 3 months. See link for details.
  • $240 Annual Flexible Business Credit. Earn up to $20 in statement credits monthly after you use the Business Gold Card for eligible U.S. purchases at FedEx, Grubhub, and Office Supply Stores.
  • $155 Annual Walmart+ Credit. Get $12.95 back in statement credits each month when you pay for a monthly Walmart+ membership (subject to auto-renewal) with your Business Gold Card.
  • Annual fee is $375. (See Rates and Fees)
  • Terms Apply.

Hawaiian Airlines Business MasterCard

  • 70,000 Hawaiian miles. 60,000 miles after $2,000 in purchases in first 90 days. 10,000 miles after a qualifying purchase is made on an employee card. See link for details.
  • Receive a one-time 50% off companion discount for roundtrip coach travel between Hawaii and The Mainland on Hawaiian Airlines.
  • $99 annual fee.

Bank of America Business Advantage Cash Rewards Card

  • $500 statement credit after $5,000 in purchases in the first 90 days. See link for details.
  • 3% cash back on your choice of six categories. 2% cash back on dining and unlimited 1% cash back on all other purchases. The 3% and 2% cash back applies to the first $50,000 in combined category/dining purchases each calendar year, 1% thereafter.
  • No annual fee.

US Bank Business Leverage Card

  • 75,000 bonus points after $7,500 in purchases (on the Account Owner’s Card only) in first the 120 days. 75,000 bonus points can be redeemed for $750 in cash back. See link for details.
  • Availability may be restricted to certain states.
  • $0 annual fee for the first year, then $95.

JetBlue Business Card

  • 60,000 TrueBlue points 50,000 points after $4,000 in purchases in first 90 days. Plus, earn 10,000 bonus points when a purchase is made on an employee card in the first 90 days. See link for details.
  • First checked bag free for the primary cardmember and up to 3 companions when tickets are purchased with your JetBlue Plus Card.
  • $99 annual fee.

Alaska Airlines Visa Business Card (Bank of America)

  • 75,000 Alaska miles + Companion Fare Voucher after $4,000 in purchase within 90 days. See link for details.
  • Companion fare voucher is “Buy one ticket, get one for $122” ($99 fare plus taxes and fees from just $23).
  • Free checked bag on Alaska flights for you and up to six other passengers on the same reservation (worth $60 roundtrip per person).
  • $70 annual fee for company, plus $25 per card.

* Note: Certain Chase cards have a “5/24 rule” which is an unofficial rule that they will automatically deny approval on new credit cards if you have 5 or more new credit cards on your credit report within the past 2 years. This rule applies on a per-person basis, so if you are new, you might want to start with those Chase cards.

For rates and fees of The Business Platinum® Card from American Express, please visit here. For rates and fees of The Hilton Honors American Express Business Card, please visit here. For rates and fees of Marriott Bonvoy Business® American Express® Card, please visit here. For rates and fees of the American Express® Business Gold Card, please visit here.


“The editorial content here is not provided by any of the companies mentioned, and has not been reviewed, approved or otherwise endorsed by any of these entities. Opinions expressed here are the author's alone. This email may contain links through which we are compensated when you click on or are approved for offers.”

Top 10 Best Small Business Credit Card Bonus Offers – April 2024 from My Money Blog.

Copyright © 2004-2022 MyMoneyBlog.com. All Rights Reserved. Do not re-syndicate without permission.

Categories: Finance

Distribution Release: Garuda Linux 240428

DistroWatch.com - Sun, 04/28/2024 - 21:26
The DistroWatch news feed is brought to you by TUXEDO COMPUTERS. Garuda Linux is a rolling, desktop distribution based on the Arch Linux operating system. The project's latest release, Garuda Linux 240428, ships with a number of upgrades, the most immediately apparent being the new Plasma 6 desktop: "The main focus of this release is certainly the already mentioned....
Categories: Linux

DistroWatch Weekly, Issue 1068

DistroWatch.com - Sun, 04/28/2024 - 19:08
The DistroWatch news feed is brought to you by TUXEDO COMPUTERS. This week in DistroWatch Weekly: Review: Fedora 40 "KDE"News: Debian elects new Project Leader, Ubuntu's security enhancements, Red Hat extends support for RHEL 7, Emmabuntus adds accessibility featuresQuestions and answers: Transform one distribution into anotherReleased last week: Fedora 40, Ubuntu 24.04, NetBSD 9.4, EndeavourOS 2024.04.20, TrueNAS 24.04.0 "SCALE"Torrent....
Categories: Linux

My Jewish college kid is protesting the war in Gaza. And I’m proud.

PenelopeTrunk.com - Sun, 04/28/2024 - 14:35

In the last 48 hours many of Y’s friends have been arrested for being part of an anti-war encampment at their college. I am shocked by the large number of college encampments across the US, but I knew this was coming because Y (who goes by they) has been discussing it for months.

We are Jewish, and like many Jewish families, our sense of activism is strong. But it wasn’t as easy for me to get my head around the pro-Palestinian rallies 0ver last six months.

My extended family has a wide range of views on the topic — there are Zionists on one end and  Y on the other. I am somewhere in the middle, which is to say I think the Israel-Hamas conflict has become horrifying and I have no idea how to fix it. This disappoints Y because the ethical discussion is so clear to them.

Before Y was born, Nino and I opened our home to a Palestinian kid who was 16 years old in NYC with nowhere to go.

His name was Tariq. It was just after 9/11 and Nino was working full time to help illegally detained people from the Middle East. Tariq’s dad was detained and Tariq had no relatives in the US.

Tariq’s dad was in the US raising money for Palestinians. I wasn’t sure what I thought about that cause, but I knew it was wrong to have the dad imprisoned for 9/11, and I knew Tariq needed a place to live until he could get back home.

Tariq had no life skills. He had spent his entire life fighting for his homeland. He learned everything about the fight from his dad, but no one taught Tariq how to make himself breakfast. We thought maybe it was that our food was unfamiliar, but actually, he had never used a stove.

He was on high alert at all times. Totally traumatized. We tried our best to support him, but we really had no idea how to cope with the level of trauma he had. Finally, someone took him back to his family in Gaza.

Periodically Nino would try to figure out where Tariq and his dad were. How they were doing. But it’s not like you can stalk them on Facebook.

Now, 25 years later, I still see no grand solution to the Israeli-Palestinian conflict. But I am sure there’s another generation of Palestinian kids never learning to cook or shop for food, because their childhood will be consumed by fighting and recovering from fighting and fearing the start of more fighting.

This is why I can support Y in their endeavors to stop the war in Gaza. Because we didn’t know if Tariq’s family was on the right or the wrong side but we knew he was a kid who needed help. And I see Y looking at the human destruction and I am not surprised by their reaction.

What did surprise me is that while Y protested their school’s financial support to Israel, Y’s Jewish identity grew.

Y’s school organizers have been careful all along to show that Jewish kids were organizing; that a person can love being Jewish and hate the war in Gaza. So when Passover came around, the kids had a seder in the encampment. Y had never gone to seder at school, so this is their first student-led seder. They said they’ve never been more proud to be Jewish. They were happy to know all the prayers and all the songs. They were happy that non-Jews participated as well. This is from the kid who announced God is not real during their bar mitzvah.

At the seder each kid had written the phone number of a lawyer on their arm in case they got arrested. But the intent was to be peaceful, so arrests were unlikely. That is, until a pro-Israel student shouted “kill the Jews” and then the state police arrested everyone because the protests had become anti-semetic. This speaks to tension on campus, for sure. But also it speaks to how savvy today’s kids are about protesting.

Anyway, the kids got out of jail fast enough to get back to campus the same day. They reorganized right away, including rotating shifts to study for finals. I love that what my kid is learning in college is how to protect free speech, how to stand up for what matters, and how to shape their own identity.

That night the group planned a Havdalah service at the encampment spot. I don’t know if Y has ever even done Havdalah. But now Y talks about it like it’s an essential part of the Jewish week: I’m kvelling.

The post My Jewish college kid is protesting the war in Gaza. And I’m proud. appeared first on Penelope Trunk Careers.

Categories: Life

OS Release: RISC OS 5.30

DistroWatch.com - Sun, 04/28/2024 - 01:08
The DistroWatch news feed is brought to you by TUXEDO COMPUTERS. Steve Revill has announced the release of RISC OS 5.30, the latest stable version of the independently-developed computer operating system originally designed by Acorn Computers Ltd in 1987. It is available for some of the popular ARM computer boards, such as Beagleboard, IOMD, Iyonix, OMAP5, Pandaboard, Raspberry Pi....
Categories: Linux

What’s KernelCare?

LinuxJournal.com - Wed, 03/30/2022 - 11:00
by Suparna Ganguly

This article explains all that you need to know about KernelCare. But before studying about KernelCare, let’s do a quick recap of the Linux kernel. It’ll help you understand KernelCare better. The Linux kernel is the core part of Linux OS. It resides in memory and prompts the CPU what to do.

Now let’s begin with today’s topic which is KernelCare. And if you’re a system administrator this article is going to present valuable information for you.

What is KernelCare?

So, what’s KernelCare? KernelCare is a patching service that offers live security updates for Linux kernels, shared libraries, and embedded devices. It patches security vulnerabilities inside the Linux kernel without creating service interruptions or any downtime. Once you install KernelCare on the server, security updates automatically get applied every 4 hours on your server. It dismisses the need for rebooting your server after making updates.

It is a commercial product and is licensed under GNU GPL version 2. Cloud Linux, Inc developed this product. The first beta version of KernelCare was released in March 2014 and its commercial launch was in May 2014. Since then they have added various useful integrations for automation tools, vulnerability scanners, and others. 

Operating systems supported by KernelCare include CentOS/RHEL 5, 6, 7; Cloud Linux 5, 6; OpenVZ, PCS, Virtuozzo, Debian 6, 7; and Ubuntu 14.04.

Is KernelCare Important?

Are you wondering if KernelCare is important for you or not? Find out here. By installing the latest kernel security patches, you are able to minimize potential risks. When you try to update the Linux kernel manually, it may take hours. Apart from the server downtime, it can be a stressful job for the system admins and also for the clients.

Once the kernel updates are applied, the server needs a reboot. This is usually done during off-peak work hours. And this causes some additional stress. However, ignoring server reboots can cause a whole lot of security issues. It’s seen that, even after rebooting, the server experiences issues and doesn’t easily come back up. Fixing such issues is a trouble for the system admins. Often the system admin needs to roll back all the applied updates to get the server up quickly.

With KernelCare, you can avoid such issues.

How Does KernelCare Work?

KernelCare eliminates non-compliance and service interruptions caused by system reboots. KernelCare agent resides on your server. It periodically checks for new updates. In case it finds any, the agent downloads those and applies them to the running kernel. A KernelCare patch can be defined as a piece of code that’s used to substitute buggy code in the kernel. 

Go to Full Article
Categories: Linux

Getting Started with Docker Semi-Self-Hosting on Linode

LinuxJournal.com - Tue, 03/29/2022 - 11:00
by David Burgess

With the evolution of technology, we find ourselves needing to be even more vigilant with our online security every day. Our browsing and shopping behaviors are also being continuously tracked online via tracking cookies being dropped on our browsers that we allow by clicking the “I Accept” button next to deliberately long agreements on websites before we can get the full benefit of said site.

Watch this article:

Additionally, hackers are always looking for a target and it's common for even big companies to have their servers compromised in any number of ways and have sensitive data leaked, often to the highest bidder.

These are just some of the reasons that I started looking into self-hosting as much of my own data as I could.

Because not everyone has the option to self-host on their own, private hardware, whether it's for lack of hardware, or because their ISP makes it difficult or impossible to do so, I want to show you what I believe to be the next best step, and that's a semi-self-hosted solution on Linode.

Let's jump right in!

Setting up a Linode

First things first, you’ll need a Docker server set up. Linode has made that process very simple and you can set one up for just a few bucks a month and can add a private IP address (for free) and backups for just a couple bucks more per month.

Get logged into your Linode account click on "Create Linode".

Don't have a Linode account?  Get $100 in credit clicking here

On the "Create" page, click on the "Marketplace" tab and scroll down to the "Docker" option. Click it.

With Docker selected, scroll down and close the "Advanced Options" as we won't be using them.

Below that, we'll select the most recent version of Debian (version 10 at the time of writing).

In order to get the the lowest latency for your setup, select a Region nearest you.

When we get to the "Linode Plan" area, find an option that fits your budget. You can always start with a small plan and upgrade later as your needs grow.

Next, enter a "Linode Label" as an identifier for you. You can enter tags if you want.

Enter a Root Password and import an SSH key if you have one. If you don't that's fine, you don't need to use an SSH key. If you'd like to generate one and use it, you can find more information about how to do so here "Creating an SSH Key Pair and Configuring Public Key Authentication on a Server").

Go to Full Article
Categories: Linux

Manage Java versions with SDKMan

OpenSource.com - Tue, 03/15/2022 - 01:01
Manage Java versions with SDKMan Seth Kenlon Tue, 03/15/2022 - 02:01 Up Register or Login to like.

Java is more than just a programming language: It's also a runtime.

Applications written in Java are compiled to Java bytecode then interpreted by a Java Virtual Machine (JVM), which is why you can write Java on one platform and have it run on all other platforms.

A challenge can arise, however, when a programming language and an application develop at different rates. It's possible for Java (the language) to increment its version number at the same time your favorite application continues to use an older version, at least for a while.

If you have two must-have applications, each of which uses a different version of Java, you may want to install both an old version and a new version of Java on the same system. If you're a Java developer, this is particularly common, because you might contribute code to several projects, each of which requires a different version of Java.

The SDKMan project makes it easy to manage different versions of Java and related languages, including Groovy, Scala, Kotlin, and more.

SDKMan is like a package manager just for versions of Java.

More on Java What is enterprise Java programming? Red Hat build of OpenJDK Java cheat sheet Free online course: Developing cloud-native applications with microservices arc… Fresh Java articles Install SDKMan

SDKMan requires these commands to be present on your system:

  • zip
  • unzip
  • curl
  • sed

On Linux, you can install these using your package manager. On Fedora, CentOS Stream, Mageia, and similar:

$ sudo dnf install zip unzip curl sed

On Debian-based distributions, use apt instead of dnf. On macOS, use MacPorts or Homebrew. On Windows, you can use SDKMan through Cygwin or WSL.

Once you've satisfied those requirements, download the SDKMan install script:

$ curl "https://get.sdkman.io" --output sdkman.sh

Take a look at the script to see what it does, and then make it executable and run it:

$ chmod +x sdkman.sh
$ ./sdkman.shConfigure

When the installation has finished, open a new terminal, or run the following in the existing one:

source "~/.sdkman/bin/sdkman-init.sh"

Confirm that it's installed:

$ sdk versionInstall Java with SDKMan

Now when you want to install a version of Java, you can do it using SDKMan.

First, list the candidates for Java available:

$ sdk list java
=================================================
Available Java Versions for Linux 64bit
=================================================
Vendor   | Version      | Dist | Identifier
-------------------------------------------------
Gluon    | 22.0.0.3.r17 | gln  | 22.0.0.3.r17-gln
         | 22.0.0.3.r11 | gln  | 22.0.0.3.r11-gln
GraalVM  | 22.0.0.2.r17 | grl  | 22.0.0.2.r17-grl
         | 21.3.1.r17   | grl  | 21.3.1.r17-grl
         | 20.3.5.r11   | grl  | 20.3.5.r11-grl
         | 19.3.6.r11   | grl  | 19.3.6.r11-grl
Java.net | 19.ea.10     | open | 19.ea.10-open
         | 18           | open | 18-open
         | 17.0.2       | open | 17.0.2-open
         | 11.0.12      | open | 11.0.12-open
         | 8.0.302      | open | 8.0.302-open
[...]

This provides a list of different Java distributions available across several popular vendors, including Gluon, GraalVM, OpenJDK from Java.net, and many others.

You can install a specific version of Java using the value in the Identifier column:

$ sdk install java 11.0.12-open

The sdk command uses tabbed completion, so you don't need to view a list. Instead you can type sdk install java 11 and then press Tab a few times to get the options.

Alternately, you can just install the default latest version:

$ sdk install javaSet your current version of Java

Set the version of Java for a terminal session with the use subcommand:

$ sdk use java 17.0.2-open

To set a version as default, use the default subcommand:

$ sdk default java 17.0.2-open

Get the current version in effect using the current subcommand:

$ sdk current java Using java version 17.0.2-openRemoving Java with SDKMan

You can remove an installed version of Java using the uninstall subcommand:

$ sdk uninstall java 11.0.12-openMore SDKMan

You can do more customization with SDKMan, including updating and upgrading Java versions and creating project-based environments. It's a useful command for any developer or user who wants the ability to switch between versions of Java quickly and easily.

If you love Java, or use Java, give SDKMan a try. It makes Java easier than ever!

The SDKMan project makes it easy to manage different versions of Java and related languages, including Groovy, Scala, Kotlin, and more.

Image by:

Image by WOCinTech ChatCC BY 2.0

Java What to read next This work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License. 6482 points (Correspondent) Vancouver, Canada

Seldom without a computer of some sort since graduating from the University of British Columbia in 1978, I have been a full-time Linux user since 2005, a full-time Solaris and SunOS user from 1986 through 2005, and UNIX System V user before that.

On the technical side of things, I have spent a great deal of my career as a consultant, doing data analysis and visualization; especially spatial data analysis. I have a substantial amount of related programming experience, using C, awk, Java, Python, PostgreSQL, PostGIS and lately Groovy. I'm looking at Julia with great interest. I have also built a few desktop and web-based applications, primarily in Java and lately in Grails with lots of JavaScript on the front end and PostgreSQL as my database of choice.

Aside from that, I spend a considerable amount of time writing proposals, technical reports and - of course - stuff on https://www.opensource.com.

Open Sourcerer People's Choice Award 100+ Contributions Club Emerging Contributor Award 2016 Correspondent Columnist Contributor Club Author Comment Gardener Register or Login to post a comment.
Categories: OpenSource

Open exchange, open doors, open minds: A recipe for global progress

OpenSource.com - Tue, 03/15/2022 - 01:00
Open exchange, open doors, open minds: A recipe for global progress Ron McFarland Tue, 03/15/2022 - 02:00 Up Register or Login to like.

Could open organization principles successfully apply to entire societies?

That's the question I asked as I read the book Open: The Story of Human Progress by Johan Norberg, which aims to examine the relative success of "open societies" throughout global history.

Learn about open organizations Download resources Join the community What is an open organization? How open is your organization?

In this review—the first article in an extended discussion of the work from Open Organization community members—I will summarize more precisely what Norberg means when he uses the term "open" and offer an initial assessment of his arguments. Ultimately, however, our discussion will explore more expansive themes, like:

  1. the importance of open societies,
  2. what the future could (or should) look like in a more open world, and
  3. how these principles impact our collective understanding of how organizations operate in service of "the greater good"
Four dimensions of openness

Essentially, Norberg is looking at four dimensions of "open," which he calls:

  1. "open exchange" (global goods and service flows across borders),
  2. "open doors" (global movement of people),
  3. "open minds" (global receptivity to new and different ideas), and
  4. "open societies" (how cultures should be governed to benefit from the above three)

Let me discuss each one more extensively.

Open exchange

Norberg uses the phrase "open exchange" to refer to the movement of goods and services not just across borders but within them as well. Simply put, he believes that people across the world prosper when trade increases, because increased trade leads to increased cooperation and sharing.

His argument goes like this: when a nation (and to be sure, Norberg aims his advice at contemporary nation-states) allows and includes foreign goods into their market, in general they also gain expertise, skills, and knowledge, too. Surplus goods/services that one may have should be sold anywhere they might provide value and add benefit for someone else—and those benefits might include, for example, favors, ideas, knowledge, not just goods and services themselves. Reciprocity and relatively equal exchange is for Norberg an unavoidable aspect of human nature, as it builds binding relationships that promote more generosity. Generosity in turn promotes more trade, creating a cycle of prosperity for all involved.

This view holds for organizations working with uncommon trade partners as well. Greater organizational specificity leads to the need for more cooperation and sharing, which leads to even more specialization. So here we can see a link between open societies and open organizations regarding trade issues.

Open doors

For Norberg, "open doors" refers to people's ability to move across national borders, for one reason or another. He believes the gradual inclusion of foreigners into a society leads to more novel and productive interactions, which leads to greater innovation, more ideas, and more rapid discoveries. For a society to be productive, it must get the right talent performing the right tasks. Norberg argues that there should be no barriers to that match-up, and people should be mobile, even across borders, so they can achieve it.

Norberg outlines how, throughout history, diverse groups of people solve problems more effectively—even if they create more friction as they do so, as members have their assumptions questioned. This kind of open environment must be promoted, supported, and managed, however, in order to avoid groupthink, the predominance of voices that are merely the loudest, and the outsized influence of niche interests.

Critical to the success of "open doors" are recognition, respect, understanding, acceptance, and inclusivity toward others. Norberg discusses the importance of these qualities, citing the World Values Survey, which measures some of them. Done well, open doors can allow societies to cross-fertilize, borrowing ideas and technology from each other and multiplying that which works best.

We could say that's equally true for an organization wanting to develop a new product or market, too.

Open minds

"Open economies stimulate open-mindedness," Norberg writes. For him, "open minds" are those receptive to thoughts and belief systems that may seem different, foreign, or alien to them—those that both offer and receive different perspectives. Open minds, Norberg claims, lead to more rapid progress.

Open minds flourish when given the space to encounter new ideas and explore them freely—rather than, say, simply accept the given dogma of an age. According to Norberg, people from a wide range of disciplines, specialties, and skills coming together and sharing their perspectives stimulates growth and progress. But this is only possible when they exist in an environment where they feel free to question the status quo and possibly overturn long-standing beliefs. Barriers to creating those environments certainly exist (in fact, the entire second half of Norberg's book offers a deeper analysis of them).

Open minds flourish when given the space to encounter new ideas and explore them freely—rather than, say, simply accept the given dogma of an age.

Of course this is true in organizations as well. The more people (and the more different people) who look at a problem, the better. This not only leads to faster solutions but helps overcome anyone's individual biases. Serendipitous solutions to problems can seemingly come out of nowhere more often, as there will be better and more peer review of strongly held positions. And yet differences create friction, so standards of protocol and behavior are required to ensure progress.

For Norberg, the world benefits when scientists, philosophers, industrialists, and craftspeople can influence one another's thinking (and are receptive to having their thinking changed!). The same is true in open organizations when people with different roles and functions can work together and enrich one another's thinking. More experiments and greater collaboration among disciplines lead to richer discoveries.

Open Organization resources Download resources Join the community What is an open organization? How open is your organization? Open societies

Combining open minds, open exchange, and open doors can lead to fully open societies globally, Norberg argues, and "the result is discoveries and achievements." Governments, he asserts, should work to foster those kinds of societies across the globe. In this way, societies can tap into the greatest talent from the entire global community.

According to Norberg, more inclusive societies based on these open policies can lead to material gains for people—fewer hours working, the ability to launch careers earlier (or retire earlier), longer lives in general, and more. This is not to mention reductions in extreme poverty, child and maternal mortality, and illiteracy globally. On top of that, for Norberg global cultural collaboration leads to better utilization of ecological, natural, and environmental resources. All this can be achieved through specific specialties that advance societies at an exponential rate though openness.

Open makes a historical argument. Norberg believes that throughout the ages it was not defenders of tradition that prospered most. Instead, those thinkers, engineers, and philosophers that challenged the status quo made the greatest contribution to global prosperity. Those figures benefitted from societies that were more open to improvements because they governed their own experiments, fostered rapid feedback loops, and built systems that quickly self-correct during setbacks.

Yet like any history, Norberg's is partial and selective, presenting isolated cases and examples. And some of those include even the most brutal empires, whose violence Norberg tends to overlook. In future parts of this review, we'll dive more deeply into various aspects of Norberg's analysis—and discuss its implications for thinking about a more open future.

Openness, this new book argues, has always been a necessary cornerstone of human civilization.

Image by:

Opensource.com

The Open Organization What to read next This work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License. Register or Login to post a comment.
Categories: OpenSource

22 Raspberry Pi projects to try in 2022

OpenSource.com - Mon, 03/14/2022 - 13:00
22 Raspberry Pi projects to try in 2022 Opensource.com Mon, 03/14/2022 - 14:00 Up 1 reader likes this

The possibilities for Raspberry Pi projects continue to perpetuate this Pi Day! The beloved single-board computer recently turned ten years old. To celebrate, we put together a list of recent Raspberry Pi tutorials written by members of the Opensource.com community. 

More on Raspberry Pi What is Raspberry Pi? eBook: Guide to Raspberry Pi Getting started with Raspberry Pi cheat sheet eBook: Running Kubernetes on your Raspberry Pi Whitepaper: Data-intensive intelligent applications in a hybrid cloud blueprint Understanding edge computing Our latest on Raspberry Pi 10 Raspberry Pi projects for your home

The Raspberry Pi is ripe for DIY projects for the home. Why risk your data with a proprietary home automation tool when you can take full control with a $35 computer? Opensource.com authors have shared how they've built thermostats, monitored their home climate, set parental controls, and much more in the following tutorials.

5 Raspberry Pi projects for productivity

You can be productive without a ton of fancy tools. Whether you want to host your personal blog or start crypto trading with a reduced carbon footprint, the Raspberry Pi has you covered.

7 Raspberry Pi projects just for fun!

The Raspberry Pi is probably most famous for its serious use case of fun! The Pi offers lots of options for tinkering with Linux, learning about computers, or celebrating your favorite holiday.

Go ahead and mark your calendar for trying out a few of these creative Raspberry Pi projects this year.

Celebrate Pi Day by checking out these creative and useful Raspberry Pi projects.

Image by:

Dwight Sipler on Flickr

Raspberry Pi What to read next Build a router with mobile connectivity using Raspberry Pi How I run my blog on a Raspberry Pi Control your Raspberry Pi remotely with your smartphone This work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License. Register or Login to post a comment.
Categories: OpenSource

Collect sudo session recordings with the Raspberry Pi

OpenSource.com - Mon, 03/14/2022 - 01:00
Collect sudo session recordings with the Raspberry Pi Peter Czanik Mon, 03/14/2022 - 02:00 Up 1 reader likes this

I've used the sudo command for years, and one of my favorite features is how it saves a record of everything happening in a terminal while running a command. This feature has been available for over a decade. However, sudo 1.9 introduced central session recording collection, allowing you to check all administrative access to your hosts on your network at a single location and play back sessions like a movie.

I use this feature on my Raspberry Pi, and I recommend it to other Pi users. Even if you fully trust your users, logs and session recordings can help debug what happened on a given host if it acts strangely: Oops, wrong file deleted in /etc.

More on Raspberry Pi What is Raspberry Pi? eBook: Guide to Raspberry Pi Getting started with Raspberry Pi cheat sheet eBook: Running Kubernetes on your Raspberry Pi Whitepaper: Data-intensive intelligent applications in a hybrid cloud blueprint Understanding edge computing Our latest on Raspberry Pi Why sudo?

Sudo gives administrative access to users. Unless you limit access to a short list of commands, you practically provide full access to your hosts. The pi user can use sudo without even entering a password on the Raspberry Pi OS. On other operating systems, the default configuration grants members of the wheel group full administrative access.

Before you begin

The new sudo_logsrvd application handles collection. Earlier versions of the Raspberry Pi OS only had sudo version 1.8. The latest version is based on Debian 11 and includes sudo version 1.9.5. You also need a second host with sudo 1.9, which sends recordings to sudo_logsrvd.

Configuring sudo_logsrvd

For a production environment, I recommend using TLS encrypted connections between sudo and sudo_logsrvd. However, to simply understand how session recording works, you can go without encryption. This also means that there is nothing to configure other than creating the storage directory and starting sudo_logsrvd:

$ sudo mkdir /var/log/sudo-io
$ sudo chmod 700 /var/log/sudo-io
$ sudo sudo_logsrvd

The sudo_logsrvd is now waiting for connections.

Configuring sudo

Configure sudo 1.9 on a host using visudo and append the following lines to the sudoers file. You will need to replace the IP address with the one of your Raspberry Pi. Note that if you do not have a second machine with sudo 1.9, you can use the same Raspberry Pi running sudo_logsrvd for testing.

Defaults ignore_iolog_errors
Defaults log_servers = 172.16.167.129:30343
Defaults log_output

The first line is your escape route while experimenting with sudo_logsrvd: It ensures that sudo works even if sudo_logsrvd is inaccessible. This configuration is not recommended for production environments as users can execute commands without proper recording.

The next two lines configure where to send recordings and enable recordings.

Testing

For testing, do something that you cannot figure out from sudo logs in syslog: A shell session. Be aware that sudo 1.9.8 changes this, but it is not yet available in Linux distributions. In this case, the logs show only that a shell is started, but nothing about what happened inside:

$ sudo -s

# id
uid=0(root) gid=0(root) groups=0(root),117(lpadmin)

# cd /root/

# ls -la
total 36
drwx------  5 root root 4096 Feb 16 12:27 .
drwxr-xr-x 18 root root 4096 Jan 28 04:22 ..
-rw-------  1 root root  827 Feb 16 12:49 .bash_history
-rw-r--r--  1 root root  571 Apr 10  2021 .bashrc
drwx------  3 root root 4096 Feb 16 10:54 .cache
-rw-------  1 root root   41 Feb 16 11:12 .lesshst
drwxr-xr-x  3 root root 4096 Feb 16 12:27 .local
-rw-r--r--  1 root root  161 Jul  9  2019 .profile
drwx------  3 root root 4096 Jan 28 04:21 .vnc

# exit
$

Even if the logs do not show anything useful, you can still use the sudoreplay command to list and playback recordings:

$ sudo sudoreplay -l
Feb 16 12:37:54 2022 : pi : TTY=/dev/pts/1 ; CWD=/home/pi ; USER=root ; HOST=raspberrypi ; TSID=000001 ; COMMAND=/usr/bin/ls -l /etc/ssl/private/
Feb 16 12:38:14 2022 : pi : TTY=/dev/pts/1 ; CWD=/home/pi ; USER=root ; HOST=raspberrypi ; TSID=000002 ; COMMAND=/usr/bin/ls -la /etc/ssl/private/
Feb 16 12:49:21 2022 : pi : TTY=/dev/pts/1 ; CWD=/home/pi ; USER=root ; HOST=raspberrypi ; TSID=000003 ; COMMAND=/bin/bash
Feb 16 12:50:03 2022 : pi : TTY=/dev/pts/1 ; CWD=/home/pi ; USER=root ; HOST=raspberrypi ; TSID=000004 ; COMMAND=/bin/bash
Feb 16 12:50:28 2022 : pi : TTY=/dev/pts/1 ; CWD=/home/pi ; USER=root ; HOST=raspberrypi ; TSID=000005 ; COMMAND=/usr/bin/sudoreplay -l

$ sudo sudoreplay 000004
Replaying sudo session: /bin/bash

# id
uid=0(root) gid=0(root) groups=0(root),117(lpadmin)
# cd /root/
# ls -la
total 36
drwx------  5 root root 4096 Feb 16 12:27 .
drwxr-xr-x 18 root root 4096 Jan 28 04:22 ..
-rw-------  1 root root  827 Feb 16 12:49 .bash_history
-rw-r--r--  1 root root  571 Apr 10  2021 .bashrc
drwx------  3 root root 4096 Feb 16 10:54 .cache
-rw-------  1 root root   41 Feb 16 11:12 .lesshst
drwxr-xr-x  3 root root 4096 Feb 16 12:27 .local
-rw-r--r--  1 root root  161 Jul  9  2019 .profile
drwx------  3 root root 4096 Jan 28 04:21 .vnc

# exit
$What is next?

I hope you learned something new today and will try it on your own Raspberry Pi. The setup I described here is good enough for testing. For production use, I recommend creating a startup script for sudo_logsrvd, which is missing from the Debian package, and you should use TLS between sudo and sudo_logsrvd. You can learn more about configuring TLS encryption from the documentation or my blog. The nice thing is that you can also use sudo_logsrvd on the Raspberry Pi in production in your home or small office. Unless you have dozens of sudo clients all utilizing the terminal heavily (like ls -laR /), not even the SD card of the Pi is a bottleneck.

Logs and session recordings can help debug what happened on a given host if it acts strangely. Try this setup on your Raspberry Pi.

Raspberry Pi Sysadmin What to read next 22 Raspberry Pi projects to try in 2022 This work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License. Register or Login to post a comment.
Categories: OpenSource

Use your Raspberry Pi as a data logger

OpenSource.com - Sun, 03/13/2022 - 13:00
Use your Raspberry Pi as a data logger Stephan Avenwedde Sun, 03/13/2022 - 14:00 Up 1 reader likes this

Data logging can be done for various reasons. In a previous article, I wrote about how I monitor the electricity consumption of my household. The Raspberry Pi platform is a perfect match for such applications as it allows communication with many kinds of analog and digital sensors. This article shows how to log the CPU temperature of a Raspberry Pi and create a spreadsheet-based report on demand. Logging the CPU temperature won't require any additional boards or sensors.

Even without a Raspberry Pi, you can follow the steps described here if you replace the specific parts of the code.

More on Raspberry Pi What is Raspberry Pi? eBook: Guide to Raspberry Pi Getting started with Raspberry Pi cheat sheet eBook: Running Kubernetes on your Raspberry Pi Whitepaper: Data-intensive intelligent applications in a hybrid cloud blueprint Understanding edge computing Our latest on Raspberry Pi Setup

The code is based on Pythonic, a graphical Python programming fronted. The easiest way to get started with Pythonic is to download and flash the Raspberry Pi image. If you don't have a Raspberry Pi, use one of the other installation methods mentioned on the GitHub page (e.g., Docker or Pip).

Once installed, connect the Raspberry Pi to the local network. Next, open the web-based GUI in a browser by navigating to http://pythonicrpi:7000/.

You should now see the following screen:

 

Download and unzip the example available on GitHub. The archive consists of several file types.

Use the green-marked button to upload the current_config.json, with the yellow-marked button upload the XLSX file and the remaining *.py files.

 

You should have this configuration in front of you after you upload the files:

 

Implementation

The application can be separated into two logical parts: Logging and report generation. Both parts run independently from each other.

Logging

The top part of the configuration can be summarized as the logging setup:

 

Involved elements:

  • ManualScheduler - 0x0412dbdc: Triggers connected elements on startup (or manually).
  • CreateTable - 0x6ce104a4: Assembles an SQL query which creates the working table (if not already existent).
  • Scheduler - 0x557616c2: Triggers subsequent element every 5 seconds.
  • DataAcquisition - 0x0e7b8360: Here we collect the CPU temperature and assemble an SQL query.
  • SQLite - 0x196f9a6e: Represents an SQLite database, accepts the SQL queries.

I will take a closer look at DataAcquisition - 0x0e7b8360. Open the built-in web editor (code-server) by navigating to http://pythonicrpi:8000/. You can see all the element-related *.py files in the left pane. The DataAcquisition element is based on the type Generic Pipe. Open the file with the related id:

generic_pipe_0x0e7b8360.py

 

In this element, responsible for reading the CPU temperature, you can uncomment the lines of code depending on whether you're running this on a Raspberry Pi or not.

The above code produces an SQL query that inserts a row in the table my_table containing the Unix timestamp in seconds and the actual CPU temperature (or a random number). The code is triggered every five seconds by the previous element (Scheduler - 0x557616c2). The SQL query string is forwarded to the connected SQLite - 0x196f9a6e element, which applies the query to the related SQLite database on the file system. The process logs the CPU temperature in the database with a sampling rate of 1/5 samples per second.

Report generation

The bottom network generates a report on request:

 

Involved elements:

  • ManualScheduler - 0x7c840ba9: Activates the connected Telegram bot on startup (or manually).
  • Telegram - 0x2e4148e2: Telegram bot which serves an interface for requesting and providing of reports.
  • GenericPipe- 0x2f78d74c: Assembles an SQL query comprising the data of the report.
  • SQLite - 0x5617d487:
  • ReportGenerator- 0x13ad992a: Create a XLSX-based report based on the data.

The example code contains a spreadsheet template (report_template.xlsx) which also belongs to this configuration.

Note: To get the Telegram bot running, provide a Telegram bot token to communicate with the server. core.telegram.org describes the process of creating a bot token.

The Telegram element outputs a request as a Python string when a user requests a report. The GenericPipe- 0x2f78d74c element that receives the request assembles a SQL query which is forwarded to the SQLite - 0x5617d487 element. The actual data, which is read based on the SQL query, is now sent to the ReportGenerator- 0x13ad992a, which I will take a closer look at:

generic_pipe_13ad992a.py

def execute(self):

        path = Path.home() / 'Pythonic' / 'executables' / 'report_template.xlsx'

        try:
                wb = load_workbook(path)
        except FileNotFoundError as e:
                recordDone = Record(PythonicError(e), 'Template not found')
                self.return_queue.put(recordDone)
                con.close()
                return
        except Exception as e:
                recordDone = Record(PythonicError(e), 'Open log for details')
                self.return_queue.put(recordDone)
                con.close()
                return

        datasheet = wb['Data']

        # create an iterator over the rows in the datasheet
        rows = datasheet.iter_rows(min_row=2, max_row=999, min_col=0, max_col=2)

In the first part, I use the load_workbook() of the openpyxl library to load the spreadsheet template. If successfully loaded, I acquire a reference to the actual sheet in the datasheet variable. Afterward, I create an iterator over the rows in the datasheet, which is stored in the variable rows.

        # Convert unix time [s] back into a datetime object, returns an iterator
        reportdata_dt = map(lambda rec: (datetime.datetime.fromtimestamp(rec[0]), rec[1]), self.inputData)
       
        # iterate till the first iterator is exhausted
        for (dt, val), (row_dt, row_val) in zip(reportdata_dt, rows):
                row_dt.value = dt
                row_val.value = val

        reportDate = datetime.datetime.now().strftime('%d_%b_%Y_%H_%M_%S')
        filename = 'report_{}.xlsx'.format(reportDate)
        filepath = Path.home() / 'Pythonic' / 'log' / filename
        wb.save(filepath)
        wb.close()
       
        recordDone = Record(filepath, 'Report saved under: {}'.format(filename))
        self.return_queue.put(recordDone)

The last part starts with the variable reportdata_dt: The variable holds an iterator which, when used, converts the raw Unix timestamp of the input data from the SQLite database (self.inputdata) back to a Python datetime object. Next, I zip the reportdata_dt iterator with the previously created rows iterator and iterate till the first of them is exhausted, which should be reportdata_dt. During iteration, I fill the columns of each row with the timestamp and the value. In the last step, I save the spreadsheet with a filename consisting of the actual date and time and forward the filename to the Telegram - 0x2e4148e2 element.

The Telegram - 0x2e4148e2 then loads the file from disk back into memory and sends it to the user who requested the report. This video shows the whole procedure:

 

Remote video URL

The report the user receives look like this:

 

Wrap up

This article shows how to easily convert the Raspberry Pi into a data logger. The Raspberry Pi platform allows you to interact with sensors of any kind, enabling you to monitor physical values as well as computed values. Using spreadsheets as the basis for your reports gives you a lot of flexibility and makes those reports very customizable. The openpyxl library in combination with Pythonic makes it simple to automate this process.

Here's how to log the CPU temperature of a Raspberry Pi and create a spreadsheet-based report on demand.

Image by:

Opensource.com

Raspberry Pi What to read next 22 Raspberry Pi projects to try in 2022 How I run my blog on a Raspberry Pi Collect sudo session recordings with the Raspberry Pi This work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License. Register or Login to post a comment.
Categories: OpenSource
Comment