Wednesday, December 21, 2016

Connection refused after yum update

Hi,

I had run yum update command and server updated and installed about 300 different module with kernel. After update complete, webserver(apache) and server didn't reachable. Webserver and ssh connections was said that "Connection refused"

I'm using centos 7.2 and the update include the upgrade to centos 7.3
After a reboot, the server does not change anything. On the last yum update, too many modules have been updated, so I connect in rescue mode and check all the updates the system has done.

sudo yum history list all



sudo yum history info 34































  • Check theses configuration files if theses does not change
    • etc/hosts
    • ect/networks
    • etc/host.conf
    • etc/resolve.conf
    • etc/network/interfaces
  • Mount Disk
    • fdisk -l
    • mount /dev/hda1 /mnt/
    • mount /dev/hda2 /mnt/home/
    • mount -t proc proc /proc
  • You have to chroot yourself on your partition
    • chroot /mnt/
  • Disable firewall
    • systemctl disable firewalld
Source : 

Friday, December 16, 2016

How to temporarily disable a foreign key constraint in MySQL ?

Try DISABLE KEYS or
SET FOREIGN_KEY_CHECKS=0;
make sure to
SET FOREIGN_KEY_CHECKS=1;
after.

Source : http://stackoverflow.com/questions/15501673/how-to-temporarily-disable-a-foreign-key-constraint-in-mysql

Tuesday, December 13, 2016

How To Use Find and Locate to Search for Files on a Linux

https://www.digitalocean.com/community/tutorials/how-to-use-find-and-locate-to-search-for-files-on-a-linux-vps

Save MySQL query results into a text or CSV file

MySQL provides an easy mechanism for writing the results of a select statement into a text file on the server. Using extended options of the INTO OUTFILE nomenclature, it is possible to create a comma separated value (CSV) which can be imported into a spreadsheet application such as OpenOffice or Excel or any other applciation which accepts data in CSV format.
Given a query such as
SELECT order_id,product_name,qty FROM orders
which returns three columns of data, the results can be placed into the file /tmo/orders.txt using the query:
SELECT order_id,product_name,qty FROM orders
INTO OUTFILE '/tmp/orders.txt'
This will create a tab-separated file, each row on its own line. To alter this behavior, it is possible to add modifiers to the query:
SELECT order_id,product_name,qty FROM orders
INTO OUTFILE '/tmp/orders.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n'
In this example, each field will be enclosed in “double quotes,” the fields will be separated by commas, and each row will be output on a new line separated by a newline (\n). Sample output of this command would look like:
"1","Tech-Recipes sock puppet","14.95" "2","Tech-Recipes chef's hat","18.95"
...
Keep in mind that the output file must not already exist and that the user MySQL is running as has write permissions to the directory MySQL is attempting to write the file to.

Thursday, October 20, 2016

Disabled and read-only controls

Check this out : https://www.w3.org/TR/html401/interact/forms.html#disabled

Tuesday, October 4, 2016

Eviter d'etre marqué comme spam par google

Ci joint le message :

This is the mail system at host xxxxx

I'm sorry to have to inform you that your message could not
be delivered to one or more recipients. It's attached below.

For further assistance, please send mail to postmaster.

If you do so, please include this problem report. You can
delete your own text from the attached returned message.

                   The mail system

<mail@qmail.com> (expanded from  mail@domain.com): host
    gmail-smtp-in.l.google.com[2a00:1450:400c:c07::1a] said: 550-5.7.1
    [2001:41d0:1004:21bc::      12] Our system has detected that this 550-5.7.1
    message is likely unsolicited mail. To reduce the amount of spam sent
    550-5.7.1 to Gmail, this message has been blocked. Please visit 550-5.7.1
    https://support.google.com/mail/?p=UnsolicitedMessageError 550 5.7.1  for
    more information. l130si4589472wmf.42 - gsmtp (in reply to end of DATA
    command)

Final-Recipient: rfc822; mail@gmail.com
Original-Recipient: rfc822;mail@domain.com
Action: failed
Status: 5.7.1
Remote-MTA: dns; gmail-smtp-in.l.google.com
Diagnostic-Code: smtp; 550-5.7.1 [2001:41d0:1004:21bc::      12] Our system has
    detected that this 550-5.7.1 message is likely unsolicited mail. To reduce
    the amount of spam sent 550-5.7.1 to Gmail, this message has been blocked.
    Please visit 550-5.7.1
    https://support.google.com/mail/?p=UnsolicitedMessageError 550 5.7.1  for
    more information. l130si4589472wmf.42 - gsmtp

Extrait :

Il vous faut simplement éditer vos zones DNS chez votre registrar, pour y ajouter une entrée de type TXT. L'instruction pour la cas décrit précédemment est :
v=spf1 a mx ip4:<IP> -all
Paramètres :
  • spf1 : la version de SPF
  • a : s'applique au A-record courant
  • mx : s'applique à l'entre MX courante
  • ip4<IP> : n'accepte que l'IP spécifiée (IP du serveur)
  • -all : refuse tous les autres
Ci joint la solution  : http://wiki.hoa.ro/doku.php?id=admin-systeme:mail-server-marked-as-spam-google

Wednesday, September 21, 2016

[Security] Switching Users with HTTP Basic Auth does not work

https://github.com/symfony/symfony/issues/8260

A part of the discussion
I'm experiencing an issue with HTTP Basic Auth and the SwitchUserListener. The symptoms are that switching users just does not work:
  • The firewall is configured with stateless: false and switch_user: true
  • When attempting to GET /<existing_path>?_switch_user=<valid_other_user>, the SwitchUserListenerredirectes to /<existing_path>.
  • The active token still points to the 'old' user.
After some research, I found out that this behaviour is caused by two things:
  1. The BasicAuthenticationListener is built in a way that should prevent credentials being checked again when the current token is already authenticated. This condition (among others) is being tested in line 64 and evaluates to false since $token->getUsername() !== $username. This results in the token withROLE_PREVIOUS_ADMIN to be overwritten in SecurityContext (line 75).
  2. Apparently persisting a token with ROLE_PREVIOUS_ADMIN does not work as expected. There already is anissue for this to which I added a comment.
In general, I don't know whether this is a bug or a feature that was never planned, but I would really appreciate some feedback on this. Switching users when providing the user's credentials with every request might sound strange, but there are cases in which this makes perfect sense.
Thank you in advance,

Friday, September 9, 2016

Thursday, August 25, 2016

SQL method to replace repeating blanks with single blanks

Link : http://stackoverflow.com/questions/2182877/sql-method-to-replace-repeating-blanks-with-single-blanks


down voteaccepted
Here is a simple set based way that will collapse multiple spaces into a single space by applying three replaces.
DECLARE @myTable TABLE (myTextColumn VARCHAR(50))

INSERT INTO @myTable VALUES ('0Space')
INSERT INTO @myTable VALUES (' 1 Spaces 1 Spaces. ')
INSERT INTO @myTable VALUES ('  2  Spaces  2  Spaces.  ')
INSERT INTO @myTable VALUES ('   3   Spaces  3   Spaces.   ')
INSERT INTO @myTable VALUES ('    4    Spaces  4    Spaces.    ')
INSERT INTO @myTable VALUES ('     5     Spaces  5     Spaces.     ')
INSERT INTO @myTable VALUES ('      6      Spaces  6      Spaces.      ')


select replace(
          replace(
             replace(
                LTrim(RTrim(myTextColumn)), --Trim the field
             '  ',' |'),                    --Mark double spaces
          '| ',''),                         --Delete double spaces offset by 1
       '|','')                              --Tidy up
       AS SingleSpaceTextColumn
 from @myTable
Your Update statement can now be set based:
 update @myTable
    set myTextColumn = replace(
                          replace(
                             replace(
                                LTrim(RTrim(myTextColumn)),
                             '  ',' |'),
                          '| ',''),
                       '|','')  
Use an appropriate Where clause to limit the Update to only the rows that have you need to update or maybe have double spaces.
e.g.
where 1<=Patindex('%  %', myTextColumn)
I have found an external write up on this method: REPLACE Multiple Spaces with One


Check if string contains only letters in javascript

With /^[a-zA-Z]/ you only check the first character:
  • ^: Assert postion at the beginning of the string
  • [a-zA-Z]: match a single character present in the list below:
    • a-z: A character in the range between "a" and "z"
    • A-Z: A character in the range between "A" and "Z"
If you want to check if all characters are letters, use this instead:
/^[a-zA-Z]+$/.test(str);
  • ^: Assert postion at the beginning of the string
  • [a-zA-Z]: match a single character present in the list below:
    • +: Between one and unlimited times, as many as possible, giving back as needed (greedy)
    • a-z: A character in the range between "a" and "z"
    • A-Z: A character in the range between "A" and "Z"
  • $: Assert postion at the end of the string (or before the line break at the end of the string, if any)
Or, using the case-insensitive flag i, you could simplify it to
/^[a-z]+$/i.test(str);
Or, since you only want to test, and not match, you could check for the opposite, and negate it:
!/[^a-z]/i.test(str);

10 Google chrome commands

Fonction Random SQL

Check this out : http://sql.sh/fonctions/rand

Sunday, August 14, 2016

Tests de ma configuration et du serveur DNS

Tests de la configuration
Avant de charger les nouvelles zones, on s’assure qu’elles sont correctes.

Test de named.conf

1
$ named-checkconf /etc/bind/named.conf
Si aucun message d’erreur n’apparait c’est que tout fonctionne.

Test des fichiers de zone

1
2
3
4
5
6
7
$ cd /etc/bind/zones
$ named-checkzone idneo.fr db.idneo.fr
zone idneo.fr/IN: loaded serial 2015080801
OK
$ named-checkzone idneo.fr 213.103.254.51.in-addr.arpa
zone idneo.fr/IN: loaded serial 2015080801
OK
Notre configuration fonctionne, on peut forcer bind à la prendre en compte.
1
$ service bind9 reload
Important :Maintenant que Bind9 est configuré, il faudra penser à relancer la procédure de déclaration du domaine sur le DNS secondaire d’OVH dans la manager. Les étapes seront les même que précédemment, mais aucun message d’erreur apparaîtra.

On teste à présent si notre serveur DNS répond correctement aux demandes depuis l’extérieur.
Grâce à la commande nslookup (disponible dans le paquet dnsutils) on commence par tester si la résolution de domaine fonctionne.
1
2
3
4
5
6
$ nslookup idneo.fr. vps196126.ovh.net
Server:         vps196126.ovh.net
Address:        51.254.103.213#53
Name:   idneo.fr
Address: 51.254.103.213
Tout fonctionne, on peut à présent tester la résolution inverse
1
2
3
4
5
$ nslookup 51.254.103.213 vps196126.ovh.net
Server:         vps196126.ovh.net
Address:        51.254.103.213#53
213.103.254.51.in-addr.arpa     name = idneo.fr.
On teste à présent le serveur secondaire afin de s’assurer qu’il a bien copié le fichier de résolution de domaine.
Pour cela on peut utiliser la première fonction nslookup en remplaçant vps196126.ovh.net par le nom d’host secondaire (ici sdns2.ovh.net). On peut également utiliser la commande dig qui nous fourni une multitude d’informations très utiles et notamment des informations sur les serveurs de nom gérant notre domaine.
1
2
3
$ dig idneo.fr +nssearch
SOA vps196126.ovh.net. postmaster.idneo.fr. 2015080801 600 1800 2419200 28800 from server 51.254.103.213 in 1 ms.
SOA vps196126.ovh.net. postmaster.idneo.fr. 2015080801 600 1800 2419200 28800 from server 213.251.188.141 in 0 ms.
On voit que deux serveurs de nom gèrent notre domaine et qu’ils ont tout les deux la version 2015080801 du fichier de zone.
Important : Si le serveur secondaire ne répond pas, c’est qu’il n’a pas encore chargé vos fichiers de zone. Il faudra attendre que cela soit fait pour continuer le tuto.
Si il répond, on s’assure que notre configuration est valide grâce au site https://www.zonemaster.fr/.